最近有个需求,需要实时显示系统时间,由于多处引用,如果每个都写代码,是不是有点麻烦,直接通过一个xml就可以搞定的事情就用xml搞定了,以下是实践过程中的一些方案。方案其实很简单,直接复制粘贴即可:
mport android.content.Context;
import android.os.Handler;
import android.os.Message;
import android.util.AttributeSet;
import android.widget.TextView;
import java.util.Calendar;
/**
* Created by litianyuan on 16/11/9.
*/
public class TimeView extends TextView {
private TextView textView;
private String timeString;
private TimeHandler mTimehandler=new TimeHandler();
//三个构造方法分别是代码构造,xml+style构造和xml构造
public TimeView(Context context) {
super(context);
this.textView=this;
Init(context);
}
public TimeView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
this.textView=this;
Init(context);
}
public TimeView(Context context, AttributeSet attrs) {
super(context, attrs);
this.textView=this;
Init(context);
}
//初始化方法
private void Init(Context context) {
try {
//初始化textview显示时间
updateClock();
//更新进程开始
new TimeThread().start();
}catch (Exception e){
e.printStackTrace();
}
}
//更新子线程
private class TimeThread extends Thread{
@Override
public void run() {
mTimehandler.startScheduleUpdate();
}
}
//重要的更新Handler
private class TimeHandler extends Handler{
private boolean mStopped;
private void post(){
sendMessageDelayed(obtainMessage(0),1000*(60- Calendar.getInstance().get(Calendar.SECOND)));
}
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
if (!mStopped){
updateClock();
post();
}
}
//开始更新
public void startScheduleUpdate(){
mStopped = false;
post();
}
//停止更新
public void stopScheduleUpdate(){
mStopped = true;
removeMessages(0);
}
}
private void updateClock() {
//更新时间
Calendar calendar=Calendar.getInstance();
int hour=calendar.get(Calendar.HOUR_OF_DAY);
int minute=calendar.get(Calendar.MINUTE);
timeString=hour+":"+minute;
textView.setText(timeString);
}
}
使用方法如下:
<com.mywidget.TimeView
android:id="@+id/system_time"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/white"
android:textSize="30sp"
android:textStyle="normal"/>
一切搞定
显示效果如图