btn_reset.setOnClickListener(this);

chronometer.setOnChronometerTickListener(new Chronometer.OnChronometerTickListener() {

@RequiresApi(api = Build.VERSION_CODES.N)

@Override

public void onChronometerTick(Chronometer chronometer) {

MLog.e(String.valueOf(chronometer.getBase()));

//当前时间-基准时间>20秒

if(SystemClock.elapsedRealtime()-chronometer.getBase()>20*1000)

{

chronometer.setCountDown(true);

}

}

});

btn_format_1 = findViewById(R.id.btn_format_1);

ch_format = findViewById(R.id.ch_format);

btn_format_1.setOnClickListener(this);

ch_format.setOnChronometerTickListener(new Chronometer.OnChronometerTickListener() {

@Override

public void onChronometerTick(Chronometer chronometer) {

//当前时间-基准时间

long time = SystemClock.elapsedRealtime()-chronometer.getBase();

Date d = new Date(time);

SimpleDateFormat sdf = new SimpleDateFormat(“HH:mm:ss”, Locale.US);

sdf.setTimeZone(TimeZone.getTimeZone(“UTC”));

//设置为HH:mm:ss格式

ch_format.setText(sdf.format(d));

}

});

}

@RequiresApi(api = Build.VERSION_CODES.N)

@Override

public void onClick(View v) {

switch (v.getId()){

case R.id.btn_start:

//SystemClock.elapsedRealtime(),自启动以来经过的毫秒数。

//设置基准时间

chronometer.setBase(SystemClock.elapsedRealtime());

//true,倒计时

chronometer.setCountDown(false);

chronometer.setFormat(“计时: %s 秒”);

//开始计时

chronometer.start();

break;

case R.id.btn_stop:

//结束计时

chronometer.stop();

//文字显示

ch_format.setText(“00:00”);

break;

case R.id.btn_reset:

//重置基准时间

chronometer.setBase(SystemClock.elapsedRealtime());

break;

case R.id.btn_format_1:

ch_format.setBase(SystemClock.elapsedRealtime());

ch_format.setCountDown(false);

ch_format.start();

break;

}

}

}

Format格式修改

将Format默认的显示格式是00:00(MM:SS),修改为00:00:00(H:MM:SS)的显示格式。

只要Chronometer发生变化,**「onChronometerTick」**都会被触发,所以我们可以在触发后进行处理。得到我们想要显示样式。

ch_format.setOnChronometerTickListener(new Chronometer.OnChronometerTickListener() {

@Override

public void onChronometerTick(Chronometer chronometer) {

//当前时间-基准时间

long time = SystemClock.elapsedRealtime()-chronometer.getBase();

Date d = new Date(time);

SimpleDateFormat sdf = new SimpleDateFormat(“HH:mm:ss”, Locale.US);

sdf.setTimeZone(TimeZone.getTimeZone(“UTC”));

//设置为HH:mm:ss格式

ch_format.setText(sdf.format(d));

}

});

源码分析


setBase()

public void setBase(long base) {

//设置基准时间

mBase = base;

//触发监听事件

dispatchChronometerTick();

//修改当前界面

updateText(SystemClock.elapsedRealtime());

}

dispatchChronometerTick()

//触发监听事件

void dispatchChronometerTick() {

if (mOnChronometerTickListener != null) {

mOnChronometerTickListener.onChronometerTick(this);

}

}

updateText()

「修改当前界面」,首先拿**「当前时间和mBase时间作比较」,second是两种之间的「差值」**。DateUtils把second格式化,一般是"MM:SS"或"H:MM:SS",输出text。

如果定义了format格式,利用Formatter将text进一步格式化。

//修改

private synchronized void updateText(long now) {

mNow = now;

long seconds = mCountDown ? mBase - now : now - mBase;

seconds /= 1000;

boolean negative = false;

if (seconds < 0) {

seconds = -seconds;

negative = true;

}

String text = DateUtils.formatElapsedTime(mRecycle, seconds);

if (negative) {

text = getResources().getString(R.string.negative_duration, text);

}

if (mFormat != null) {

Locale loc = Locale.getDefault();

if (mFormatter == null || !loc.equals(mFormatterLocale)) {

mFormatterLocale = loc;

mFormatter = new Formatter(mFormatBuilder, loc);

}

mFormatBuilder.setLength(0);

mFormatterArgs[0] = text;

try {

mFormatter.format(mFormat, mFormatterArgs);

text = mFormatBuilder.toString();

} catch (IllegalFormatException ex) {

if (!mLogged) {

Log.w(TAG, "Illegal format string: " + mFormat);

mLogged = true;

}

}

}

setText(text);

}

start()

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

最后

光有这些思路和搞懂单个知识的应用是还远远不够的,在Android开源框架设计思想中的知识点还是比较多的,想要搞懂还得学会整理和规划:我们常见的**Android热修复框架、插件化框架、组件化框架、图片加载框架、网络访问框架、RxJava响应式编程框架、IOC依赖注入框架、最近架构组件Jetpack等等Android第三方开源框架,**这些都是属于Android开源框架设计思想的。如下图所示:

image

这位阿里P8大佬针对以上知识点,熬夜整理出了一本长达1042页的完整版如何解读开源框架设计思想PDF文档,内容详细,把Android热修复框架、插件化框架、组件化框架、图片加载框架、网络访问框架、RxJava响应式编程框架、IOC依赖注入框架、最近架构组件Jetpack等等Android第三方开源框架这些知识点从源码分析到实战应用都讲的简单明了。

由于文档内容过多,篇幅受限,只能截图展示部分,更为了不影响阅读,这份文档已经打包在GitHub,有需要的朋友可以直接点此处前往免费下载

image

image

整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~

响应式编程框架、IOC依赖注入框架、最近架构组件Jetpack等等Android第三方开源框架这些知识点从源码分析到实战应用都讲的简单明了。**

由于文档内容过多,篇幅受限,只能截图展示部分,更为了不影响阅读,这份文档已经打包在GitHub,有需要的朋友可以直接点此处前往免费下载

[外链图片转存中…(img-SzhAWUyW-1711300186172)]

[外链图片转存中…(img-78FHuAgg-1711300186173)]

整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~

你的支持,我的动力;祝各位前程似锦,offer不断!!!

Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐