android计时器,时间计算器的实现方法,需要的朋友可以参考一下
需求:默认为"00:00:00",点击开始按钮时清零后开始计时,出现如10:28:34。点击停止的时候停止计时。
问题:使用Calendar
DateFormat的方法,不设置时区获取到的小时是本地时区的(东八区的就是8),设置成GMT标准时区获取到的时间是12小时(12:00:00),设置24小时制无效。
在开始时间加减各种小时都无效,而且计时只能到12小时就自动跳上去了,始终无法出现默认状态00:00:00开始计时的效果。
尝试各种时间设置方法无效后只能自己写一个根据秒数转换时间格式字符串的方法了,经过测试是没问题的,两位数只能显示99小时为最大,如需要更大小时数需要改改方法。
另外小时数也不能无限大,超过long数据类型长度会变成负数的,会出现异常的。
显示效果:
测试类:
复制代码
代码如下:
public class TestTime {
public
static void main(String[] args) {
TestTime tt = new
TestTime();
ttshowTimeCount(993600000+751000);
}
//时间计数器,最多只能到99小时,如需要更大小时数需要改改方法
public String
showTimeCount(long time) {
Systemoutprintln("time="+time);
if(time >=
360000000){
return "00:00:00";
}
String
timeCount = "";
long hourc = time/3600000;
String hour =
"0" + hourc;
Systemoutprintln("hour="+hour);
hour =
hoursubstring(hourlength()-2, hourlength());
Systemoutprintln("hour2="+hour);
long minuec =
(time-hourc3600000)/(60000);
String minue = "0" +
minuec;
Systemoutprintln("minue="+minue);
minue =
minuesubstring(minuelength()-2, minuelength());
Systemoutprintln("minue2="+minue);
long secc =
(time-hourc3600000-minuec60000)/1000;
String sec = "0" +
secc;
Systemoutprintln("sec="+sec);
sec =
secsubstring(seclength()-2, seclength());
Systemoutprintln("sec2="+sec);
timeCount = hour + ":" + minue +
":" + sec;
Systemoutprintln("timeCount="+timeCount);
return timeCount;
}
}
实际例子:
复制代码
代码如下:
//时间计数器,最多只能到99小时,如需要更大小时数需要改改方法
public String showTimeCount(long time) {
if(time >=
360000000){
return "00:00:00";
}
String
timeCount = "";
long hourc = time/3600000;
String hour =
"0" + hourc;
hour = hoursubstring(hourlength()-2,
hourlength());
long minuec =
(time-hourc3600000)/(60000);
String minue = "0" +
minuec;
minue = minuesubstring(minuelength()-2,
minuelength());
long secc =
(time-hourc3600000-minuec60000)/1000;
String sec = "0" +
secc;
sec = secsubstring(seclength()-2, seclength());
timeCount = hour + ":" + minue + ":" + sec;
return
timeCount;
}
private Handler stepTimeHandler;
private Runnable mTicker;
long startTime = 0;
//开始按钮
class startBtnListener implements OnClickListener {
@Override
public void onClick(View v) {
Button b =
(Button)v;
String buttonText =
bgetText()toString();
if("Start"equalsIgnoreCase(buttonText)){
bsetText("Stop");
// 清零 开始计时
stepTimeTVsetText("00:00:00");
stepTimeHandler = new
Handler();
startTime =
SystemcurrentTimeMillis();
mTicker = new Runnable()
{
public void run() {
String
content = showTimeCount(SystemcurrentTimeMillis() -
startTime);
stepTimeTVsetText(content);
long now =
SystemClockuptimeMillis();
long next = now + (1000
- now % 1000);
stepTimeHandlerpostAtTime(mTicker,
next);
}
};
//启动计时线程,定时更新
mTickerrun();
}else{
bsetText("Start");
//停止计时 Remove
any pending posts of Runnable r that are in the message
queue
stepTimeHandlerremoveCallbacks(mTicker);
}
}
}
用时间格式化的方式测试代码:
复制代码
代码如下:
//开始按钮 通过Calendar时间设置的方式,无法正常显示小时为0
class startBtnListener implements OnClickListener {
@Override
public void onClick(View v) {
Button b =
(Button)v;
String buttonText =
bgetText()toString();
if("Start"equalsIgnoreCase(buttonText)){
bsetText("Stop");
// 清零 开始计时
stepTimeTVsetText("00:00:00");
if (mCalendar == null)
{
mCalendar =
CalendargetInstance();
TimeZone tz =
TimeZonegetTimeZone("GMT");//GMT+8
mCalendarsetTimeZone(tz);
mCalendarget(CalendarHOUR_OF_DAY);//24小时制
}
stepTimeHandler = new Handler();
//SystemuptimeMillis()
//记录从机器启动后到现在的毫秒数,当系统进入深度睡眠时,此计时器将会停止
//SystemcurrentTimeMillis()
//返回自1970年1月1日到现在的毫秒数,通常用来设置日期和时间
//SystemelapsedRealtime()
//返回从机器启动后到现在的毫秒数,包括系统深度睡眠的时间,api里没有这个方法
//直接取得的是当地时区时间,当地时间跟时区有关,设置GMT后始终多12小时
startTime =
SystemcurrentTimeMillis();//123600000 - 363600000减掉或者加上12小时都不行
mTicker = new Runnable() {
public
void run() {
//这个减出来的日期是1970年的 时间格式不能出现00:00:00
12:00:00
long showTime = SystemcurrentTimeMillis()
- startTime;
Logi(TAG,showTime+"");
mCalendarsetTimeInMillis(showTime + 133600000 +
1000);
String content = (String)
DateFormatformat(mFormat, mCalendar);
stepTimeTVsetText(content);
long now =
SystemClockuptimeMillis();
long next = now + (1000
- now % 1000);
stepTimeHandlerpostAtTime(mTicker,
next);
}
};
//启动计时线程,定时更新
mTickerrun();
}else{
bsetText("Start");
//停止计时 Remove
any pending posts of Runnable r that are in the message
queue
stepTimeHandlerremoveCallbacks(mTicker);
}
}
}
private Handler stepTimeHandler;
Calendar
mCalendar;
String mFormat = "yyyy-MM-dd hh:mm:ss";//yyyy-MM-dd
long startTime = 0;
private Runnable mTicker;
android下修改时间的代码:
public void testDate(){
try {
Process process = RuntimegetRuntime()exec("su");
String datetime="20131023112800"; //测试的设置的时间时间格式 yyyyMMddHHmmss
DataOutputStream os = new DataOutputStream(processgetOutputStream());
oswriteBytes("setprop persistsystimezone GMT\n");
oswriteBytes("/system/bin/date -s "+datetime+"\n");
oswriteBytes("clock -w\n");
oswriteBytes("exit\n");
osflush();
} catch (IOException e) {
eprintStackTrace();
}
}
格林威治是英国伦敦南郊原格林威治天文台的所在地,它又是世界上地理经度的起始点。对于世界上发生的重大事件,都以格林威治的地方时间记录下来。一旦知道了格林威治时间,人们就很容易推算出相当的本地时间。 英国伦敦是0时区,北京是东八区。也就说,格林尼治时间是1日0点,那么北京是1日早8点
Commands:命令
Actions: 动作
Triggers: 触发条件
Services: 服务
Options: 选项
Propertise: 属性
(1) Commands是一些基本的 *** 作,例如:
mkdir /sdcard 0000 system system mkdir /system
mkdir /data 0771 system system
mkdir /cache 0770 system cache
mkdir /config 0500 root root
mkdir /sqlite_stmt_journals 01777 root root
mount tmpfs tmpfs /sqlite_stmt_journals size=4m
这些命令在init可执行程序中被解析,然后调用相关的函数来实现。
(2) Actions(动作)表示一系列的命令,通常在Triggers(触发条件)中调用,动作和触发条件的形式为:
on
动作的使用示例如下:
on init
export PATH /sbin:/system/sbin:/system/bin:/system/xbin
mkdir /system
init表示一个触发条件,这个触发事件发生后,进行设置环境变量和建立目录的 *** 作称为一个“动作”
(3) Services(服务)通常表示启动一个可执行程序,Options(选项)是服务的附加内容,用于配合服务使用。
service vold /system/bin/vold
socket vold stream 0660 root mount
service bootsound /system/bin/playmp3
user media
group audio
oneshot
vold和bootsound分别是两个服务的名称,/system/bin/vold和/system /bin/playmp3分别是他们所对应的可执行程序。
socket、user、group、oneshot就是配合服务使用的选项。其中oneshot选项表示该服务只启动一次,而如果没有oneshot选项,
这个可执行程序会一直存在--如果可执行程序被杀死,则会重新启动。
(4) Properties(属性)是系统中使用的一些值,可以进行设置和读取。
setprop roFOREGROUND_APP_MEM 1536
setprop roVISIBLE_APP_MEM 2048
on property:rokernelqemu=1
start adbd
setprop 用于设置属性,on property可以用于判断属性,这里的属性在整个Android系统运行中都是一致的。
init脚本的关键字可以参考init进程的system/core/init/keywordh文件。
initrc的使用方法,可以参考说明文件system/core/init/readmetxt
如果想要修改启动过程只需要修改initc(system/core/init)或者initrc里的内容即可
如何去写
Android initrc (Android init language)
Android 初始化语言由四大类声明组成 : 行为类 (Actions), 命令类 (Commands) ,服务类 (Services), 选项类 (Options)
初始化语言以行为单位,由以空格间隔的语言符号组成。 C 风格的反斜杠转义符可以用来插入空白到语言符号。双引号也可以用来防止文本被空格分成多个语言符号。当反斜杠在行末时,作为折行符。
以 # 开始 ( 前面允许有空格 ) 的行为注释行。
Actions 和 Services 隐含声明一个新的段落。所有该段落下 Commands 或 Options 的声明属于该段落。第一段落前的 Commands 或Options 被忽略。
Actions 和 Services 拥有独一无二的命名。在它们之后声明相同命名的类将被当作错误并忽略。
Actions
-------
Actions 是一系列命令的命名。 Actions 拥有一个触发器 (trigger) 用来决定 action 何时执行。当一个 action 在符合触发条件被执行时,如果它还没被加入到待执行队列中的话,则加入到队列最后。
队列中的 action 依次执行, action 中的命令也依次执行。 Init 在执行命令的中间处理其它活动 ( 设备创建 / 销毁 ,property 设置,进程重启) 。
Actions 表现形式为:
on
Services
--------
Services 是由 init 启动,在它们退出时重启 ( 可选 ) 。 Service 表现形式为 :
service [ ]
Options
-------
Options 是 Services 的修饰,它们影响 init 何时、如何运行 service
critical
这是一个设备关键服务 (device-critical service) 如果它在 4 分钟内退出超过 4 次,设备将重启并进入恢复模式。
disabled
这个服务的级别将不会自动启动,它必须被依照服务名指定启动才可以启动。
setenv
设置已启动的进程的环境变量 的值
socket [ [ ] ]
创建一个名为 /dev/socket/ 的 unix domin socket ,并传送它的 fd 到已启动的进程。 必须为 "dgram" 或 "stream" 用户和组默认为 0
user
在执行服务前改变用户名。当前默认为 root 如果你的进程需要 linux 能力,你不能使用这个命令。你必须在还是 root 时请求能力,并下降到你需要的 uid
group [ ]
在执行服务前改变组。在第一个组后的组将设为进程附加组 ( 通过 setgroups()) 当前默认为 root
oneshot
在服务退出后不重启。
class
为 service 指定一个类别名。同样类名的所有的服务可以一起启动或停止。如果没有指定类别的服务默认为 "default" 类。
onrestart
当服务重启时执行一个命令。
Triggers
--------
Triggers( 触发器 ) 是一个字符串,可以用来匹配某种类型的事件并执行一个 action 。
boot
这是当 init 开始后执行的第一个触发器 ( 当 /initconf 被加载 )
=
当 property 被设为指定的值 时触发。
device-added-
device-removed-
当设备节点被添加或移除时触发。
service-exited-
当指定的服务存在时触发
Commands
--------
exec [ ]
Fork 并执行一个程序 () 这将被 block 直到程序执行完毕。最好避免执行例如内建命令以外的程序,它可能会导致 init 被阻塞不动。
export
设定全局环境变量 的值 ,当这个命令执行后所有的进程都可以取得。
ifup
使网络接口 联机。
import
解析一个 init 配置文件,扩展当前配置文件。
hostname
设置主机名
chmod
改变文件访问权限
chown
改变文件所属和组
class_start
当指定类别的服务没有运行,启动该类别所有的服务。
class_stop
当指定类别的服务正在运行,停止该类别所有的服务。
domainname
设置域名。
insmod
加载该路径 的模块
mkdir [mode] [owner] [group]
在 创建一个目录 , 可选选项 :mod,owner,group 如果没有指定,目录以 755 权限, owner 为 root,group 为 root 创建
mount
[ ]
尝试 mount 到目录
可以用 mtd@name 格式以命名指定一个 mtd 块设备。 包含"ro","rw","remount","noatime"
例如:
mount -t vfat -o fmask=0000,dmask=0000,rw,flush,noatime,nodiratime /dev/block/mmcblk1p1 /SD1
chown system system /SD1
chmod 0777 /SD1
mount -t vfat -o fmask=0000,dmask=0000,rw,flush,noatime,nodiratime /dev/block/mmcblk1p6 /SD3
chown system system /SD3
chmod 0777 /SD3
setkey
暂时没有
setprop
设置系统 property 的值
setrlimit
设置 resource 的 rlimit
start
启动一个没有运行的服务。
stop
停止一个正在运行的服务。
symlink
创建一个 的符号链接到
sysclktz
设置系统时区 (GMT 为 0)
trigger
触发一个事件。用于调用其它 action 。
write [ ]
打开 的文件并写入一个或多个字符串。
Properties
----------
Init 会更新一些系统 property 以提供查看它正在干嘛。
initaction
当前正在执行的 action, 如果没有则为 ""
initcommand
被执行的命令,如果没有则为 ""
initsvc
命名为 的服务的状态 ("stopped", "running", "restarting")
initrc 示例 :
-----------------
# not complete -- just providing some examples of usage
#
on boot
export PATH /sbin:/system/sbin:/system/bin
export LD_LIBRARY_PATH /system/lib
mkdir /dev
mkdir /proc
mkdir /sys
mount tmpfs tmpfs /dev
mkdir /dev/pts
mkdir /dev/socket
mount devpts devpts /dev/pts
mount proc proc /proc
mount sysfs sysfs /sys
write /proc/cpu/alignment 4
ifup lo
hostname localhost
domainname localhost
mount yaffs2 mtd@system /system
mount yaffs2 mtd@userdata /data
import /system/etc/initconf
class_start default
service adbd /sbin/adbd
user adb
group adb
service usbd /system/bin/usbd -r
user usbd
group usbd
socket usbd 666
service zygote /system/bin/app_process -Xzygote /system/bin --zygote
socket zygote 666
service runtime /system/bin/runtime
user system
group system
on device-added-/dev/compass
start akmd
on device-removed-/dev/compass
stop akmd
service akmd /sbin/akmd
disabled
user akmd
group akmd
调试
---------------
默认情况下, init 执行的程序输出的信息和错误到 /dev/null 为了 debug ,你可以通过 Android 程序 logwrapper 执行你的程序。这将复位向输出 / 错误输出到 Android logging 系统 ( 通过 logcat 访问 ) 。
===============================================================
Android——initrc脚本
在Android中使用启动脚本initrc,可以在系统的初始化中进行简单的 *** 作。
initrc启动脚本路径:system/core/rootdir/initrc
内容:
Commands:命令
Actions:动作
Triggers:触发条件
Services:服务
Options:选项
Properties:属性
Commands是一些基本 *** 作。如:
mkdir /system
mkdir /data 0771 system system
mkdir /persist 0771 system system
devwait /dev/block/mmcblk0p12
mount ext3 /dev/block/mmcblk0p
Action表示一系列命令,通常在Triggers中调用,如:
on init //表示一个触发条件
sysclktz 0
loglevel 3
# setup the global environment
export PATH /sbin:/system/sbin:/system/bin:/system/xbin
export LD_LIBRARY_PATH /system/lib
export ANDROID_BOOTLOGO 1
Services通常表示启动一个可执行程序,Options是服务的附加内容,用于配合服务使用。
service vold /system/bin/vold //vold是服务名称,/system/bin/vold是所对应的可执行程序。
socket vold stream 0660 root mount //socket是配合服务使用的选项
ioprio be 2
service netd /system/bin/netd
socket netd stream 0660 root system
配合服务使用的选项有socket,user,group,oneshot。
oneshot表示该服务只启动一次,而如果没有oneshot选项,这个可执行程序将一直存在——如果可执行程序被杀死,则会重新启动。
Properties是系统中使用的一些值,可以进行设置和读写。
setprop roHIDDEN_APP_MEM 5120 //setprop用于设置属性
setprop roCONTENT_PROVIDER_MEM 5632
setprop roEMPTY_APP_MEM 6144
on property:rokernelqemu=1 //on property用于判断属性
start adbd
这里的属性在整个android系统运行中都是一致的。
init脚本的关键字可以参考init进程中的system/core/init/keywordh文件。如:
KEYWORD(chroot, COMMAND, 1, do_chroot) //chroot是命令,do_chroot()是调用的函数,这个函数在init进程中的system/core/init/builtinsc文件中定义。
例如:
service akmd /system/bin/logwrapper /sbin/akmd
final Calendar mCalendar=CalendargetInstance();
mCalendarsetTimeInMillis(time);
取得系统日期: int mYear = mCalendarget(CalendarYEAR)
int mMonth = mCalendarget(CalendarMONTH)
int mDay = mCalendarget(CalendarDAY_OF_MONTH)
取得系统时间:int mHour= mCalendarget(CalendarHOUR_OF_DAY);
int mMinuts= mCalendarget(CalendarMINUTE)
(2)Android的文件有建议用Time代替Calendar。用Time对CPU的负荷会较小。在写Widget时特别重要。
Time mTime=new Time(); // or Time t=new Time("GMT+8"); 加上Time Zone资料。
mTimesetToNow(); // 取得系统时间。
int year = mTimeyear;
int month = mTimemonth;
int date = mTimemonthDay;
int hour =mTimehour; // 0-23
int minute = mTimeminute;
int second =mTimesecond;
唯一不足是取出时间只有24小时模式这个不叫屏幕的时间 应该叫系统时间
求采纳为满意回答。
Time time = new Time("GMT+8");
timesetToNow();
int year = timeyear;
int month = timemonth;
int day = timemonthDay;
int minute = timeminute;
int hour = timehour;
int sec = timesecond;
[DESCRIPTION]
如何修改为出厂时区为指定的时区和默认的日期?
[Solution]
时间信息预设信息都是0, 在rtc 初试化 时候设置的
由于RTC 基本上不会断电,所以它的初试化只做一次,即使重新download bin 档
用FlashTool 执行Format, 再执行download (不要用format -->download button), 或
者RTC断电一段时间,就可以观察到日期恢复到出厂值。
修改RTC默认日期:
修改文件
\alps\mediatek\custom\[project]\preloader\ inc\cust_rtch
\alps\mediatek\custom\[project]\kernel\rtc\rtc\rtc-mt65XXh
#define RTC_DEFAULT_YEA 2012
#define RTC_DEFAULT_MTH 2
#define RTC_DEFAULT_DOM 1
修改默认日期:
在JB之前,进行以上修改即可,如果是JB以后,还需要进行以下修改:
(如果下面的修改还是无效,请参考FAQ08916,FAQ08719,FAQ07606)
[File]
framework\services\java\com\android\server\NetworkTimeUpdateServicejava
[Function]
systemReady()
[Code]
if(isFirstBoot){
Time today = new Time(TimegetCurrentTimezone());
todaysetToNow(); // 将时间恢复到RTC时间
todayset(1, 0, mDefaultYear ); //设立出厂默认日期,mDefaultYear是默认年份
如果想恢复出厂设置后,系统时间不变,可使用todaysetToNow();
如果想恢复出厂设置后,系统时间也恢复成出厂时间,可使用todayset(1, 0, mDefaultYear );
这个todayset方法有6个参数的重载,可以精确到秒,具体使用方法请自行查询API,所以在这里设
置系统默认时间就可以了。
如果要设置出厂默认年份需要修改
1) mediatek\frameworks\base\res\res\values\configxml将
default_restore_year 修改成 2013
<!-- default year for first power on-->
<integer name="default_restore_year">2013</integer>
2)
frameworks\base\services\java\com\android\server\NetworkTimeUpdateService
java
if(todayyear <= 2010){ //删除此行判断条件
todayset(todaymonthDay, todaymonth, 2013);
Logd(TAG, "Set the year to 2013");
SystemPropertiesset(BOOT_SYS_PROPERTY, "false");
SystemClocksetCurrentTimeMillis(todaytoMillis(false));}
修改后的表现可通过Setting菜单->时间日期设置):
修改默认时区:
在系统属性中增加下面字段(假设改为Moscow)
路径:\alps\mediatek\config\[project]\systemprop
persistsystimezone = Europe/Moscow
注意:默认时区的修改会影响默认时间的值,会根据与格林尼治标准时间差来更新时间,这是正常
现象。如当前设置为中国标准时间GMT+8:00,则手机的出厂时间会变为8:00。
以上就是关于android中怎么使timecount自动开始计时全部的内容,包括:android中怎么使timecount自动开始计时、Android怎样修改系统时间、从系统上将JAVA的格林尼治标准时间改为北京时间等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)