我的Android进阶之旅------>Android Widget 桌面数字时钟(DigtalClockWidget)实例

简介: step1:新建项目DigtalClockWidget,并将显示时间的图片导入到drawable文件夹目录下:                                                                         ...

step1:新建项目DigtalClockWidget,并将显示时间的图片导入到drawable文件夹目录下:

                                                       

                                                   各个图片如下:

                                                                                              

step2:编写Widget的UI界面

a.  /xml/appwidget_provider.xml

<?xml version="1.0" encoding="utf-8"?>
<!--
     指定该桌面组件的基本配置信息:
	minWidth:桌面小控件的最小宽度。
	minWidth:桌面小控件的最小高度。
	updatePeriodMillis:更新频率
	initialLayout:初始时显示的布局

-->
<!--指定该Widget的布局界面为@layout/main-->
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
    android:initialLayout="@layout/main"  
    android:minHeight="30px"
    android:minWidth="300px"
    android:updatePeriodMillis="500"
   />

b./layout/main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
	android:id="@+id/digit" android:layout_width="fill_parent"
	android:layout_height="fill_parent" android:orientation="horizontal"
	android:gravity="center">

	<!-- 定义19个ImageView来显示液晶数字 -->

	<ImageView android:id="@+id/img01" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img02" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img03" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img04" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img05" android:layout_width="wrap_content"
		android:layout_height="wrap_content" android:src="@drawable/digity" />

	<ImageView android:id="@+id/img06" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img07" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img08" android:layout_width="wrap_content"
		android:layout_height="wrap_content" android:src="@drawable/digity" />

	<ImageView android:id="@+id/img09" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img10" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img11" android:layout_width="wrap_content"
		android:layout_height="wrap_content" android:src="@drawable/digite" />

	<ImageView android:id="@+id/img12" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img13" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img14" android:layout_width="wrap_content"
		android:layout_height="wrap_content" android:src="@drawable/digit" />

	<ImageView android:id="@+id/img15" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img16" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />

	<ImageView android:id="@+id/img17" android:layout_width="wrap_content"
		android:layout_height="wrap_content" android:src="@drawable/digit" />

	<ImageView android:id="@+id/img18" android:layout_width="wrap_content"
		android:layout_height="wrap_content" android:src="@drawable/digit" />

	<ImageView android:id="@+id/img19" android:layout_width="wrap_content"
		android:layout_height="wrap_content" />
</LinearLayout>


step3:AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
	package="cn.roco.widget.clock" android:versionCode="1"
	android:versionName="1.0">
	<uses-sdk android:minSdkVersion="8" />
        <uses-permission android:name="android.permission.CALL_PHONE"/>
	<application android:icon="@drawable/icon" android:label="@string/app_name">
		<!-- 指定广播接受者 -->
		<receiver android:name="TimeWidgetProvider">
			<intent-filter>
				<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
			</intent-filter>
			<meta-data android:name="android.appwidget.provider"
				android:resource="@xml/appwidget_provider" /><!-- 指定provider -->
		</receiver>
		<!-- 指定时钟服务 -->
		<service android:name=".TimeService" />
	</application>
</manifest>




step4:TimeService.java

package cn.roco.widget.clock;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;

import android.app.PendingIntent;
import android.app.Service;
import android.appwidget.AppWidgetManager;
import android.content.ComponentName;
import android.content.Intent;
import android.net.Uri;
import android.os.IBinder;
import android.widget.RemoteViews;

public class TimeService extends Service {
	// 将0~9的液晶数字图片定义成数组
	private int[] digits = new int[] { R.drawable.digit00, R.drawable.digit01,
			R.drawable.digit02, R.drawable.digit03, R.drawable.digit04,
			R.drawable.digit05, R.drawable.digit06, R.drawable.digit07,
			R.drawable.digit08, R.drawable.digit09, };

	// 将显示年 月 日 小时、分钟、秒钟的ImageView定义成数组
	private int[] digitViews = new int[] { R.id.img01, R.id.img02, R.id.img03,
			R.id.img04, R.id.img06, R.id.img07, R.id.img09, R.id.img10,
			R.id.img12, R.id.img13, R.id.img15, R.id.img16, R.id.img18,
			R.id.img19 };

	private Timer timer;

	private TimerTask timerTask = new TimerTask() {
		@Override
		public void run() {

			/** 获取并格式化当前时间 */
			SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
			String time = sdf.format(new Date());
			/** 获得显示时间的View */
			RemoteViews views = new RemoteViews(getPackageName(), R.layout.main);
			for (int i = 0; i < time.length(); i++) {
				// 将第i个数字字符转换为对应的数字
				int num = time.charAt(i) - 48;
				// 将第i张图片设为对应的液晶数字图片
				views.setImageViewResource(digitViews[i], digits[num]);
			}
			/** 调用拨号程序 */
			Intent intent = new Intent(Intent.ACTION_VIEW,
					Uri.parse("tel:10086"));
			PendingIntent pendingIntent = PendingIntent.getActivity(
					getApplicationContext(), 0, intent, 0);
			views.setOnClickPendingIntent(R.id.digit, pendingIntent);

			/** 更新时间的显示 */
			AppWidgetManager appWidgetManager = AppWidgetManager
					.getInstance(getApplicationContext());
			// 将AppWidgetProvider子类实例包装成ComponentName对象
			ComponentName componentName = new ComponentName(
					getApplicationContext(), TimeWidgetProvider.class);
			// 调用AppWidgetManager将remoteViews添加到ComponentName中
			appWidgetManager.updateAppWidget(componentName, views);
		}
	};

	@Override
	public void onCreate() {
		super.onCreate();
		// 定义计时器
		timer = new Timer();
		// 启动周期性调度
		timer.schedule(timerTask, 0, 1000);
	}

	@Override
	public IBinder onBind(Intent intent) {
		return null;
	}

	@Override
	public void onDestroy() {
		super.onDestroy();
		timer.cancel();
		timer = null;
	}

}

step5:TimeWidgetProvider.java

package cn.roco.widget.clock;

import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProvider;
import android.content.Context;
import android.content.Intent;
public class TimeWidgetProvider extends AppWidgetProvider {

	@Override
	public void onUpdate(Context context, AppWidgetManager appWidgetManager,
			int[] appWidgetIds) {
	}

	/** 当用户从桌面上删除widgets的时候被调用 */
	@Override
	public void onDeleted(Context context, int[] appWidgetIds) {
	}
	
	/**
	 * 第一次往桌面添加Widgets的时候才会被调用,
	 * 往后往桌面添加同类型的widgets时候不会被调用
	 */
	@Override
	public void onEnabled(Context context) {
		//启动服务
		context.startService(new Intent(context, TimeService.class));
	}

	/** 最后一个同类型widgets实例被删除的时候调用 */
	@Override
	public void onDisabled(Context context) {
		//停止服务
		context.stopService(new Intent(context, TimeService.class));
	}
}

step6:部署应用到模拟器上,部署完成后打开该Widget

       

应用的效果图如下:



   ==================================下面看一个gif动画===========================================

                        

该项目的源码在:http://pan.baidu.com/share/link?shareid=403033&uk=805959799


==================================================================================================

  作者:欧阳鹏  欢迎转载,与人分享是进步的源泉!

  转载请保留原文地址http://blog.csdn.net/ouyang_peng

==================================================================================================


相关文章
|
7月前
|
Android开发
Android应用实例(一)之---有道辞典VZ.0
Android应用实例(一)之---有道辞典VZ.0
43 2
|
7月前
|
API Android开发
Android高手进阶教程(十五)之---通过Location获取Address的使用!
Android高手进阶教程(十五)之---通过Location获取Address的使用!
67 1
|
5月前
|
API Android开发
Android 监听Notification 被清除实例代码
Android 监听Notification 被清除实例代码
|
6月前
|
安全 Java Android开发
使用Unidbg进行安卓逆向实例讲解
使用Unidbg进行安卓逆向实例讲解
137 2
|
6月前
|
存储 算法 Java
Android 进阶——代码插桩必知必会&ASM7字节码操作
Android 进阶——代码插桩必知必会&ASM7字节码操作
252 0
|
7月前
|
缓存 网络协议 Java
挑战全网,史上最全Android开发进阶,跳槽复习指南(1),掌握这6大技能体系
挑战全网,史上最全Android开发进阶,跳槽复习指南(1),掌握这6大技能体系
|
7月前
|
Android开发
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析
Flutter完整开发实战详解(六、 深入Widget原理),2024百度Android岗面试真题收录解析
|
7月前
|
Java Android开发
Android桌面快捷方式图标生成与删除 使用Intent与launcher交互
Android桌面快捷方式图标生成与删除 使用Intent与launcher交互
116 1
|
7月前
|
算法 安全 Java
2024年Android最新知识体系最强总结(全方面覆盖Android知识结构,BAT面试&学习进阶)
2024年Android最新知识体系最强总结(全方面覆盖Android知识结构,BAT面试&学习进阶)
|
7月前
|
消息中间件 缓存 架构师
2024年阿里Android高级面试题分享,附学习笔记+面试整理+进阶书籍
2024年阿里Android高级面试题分享,附学习笔记+面试整理+进阶书籍