前言

前不久在网上看见Android实现的模拟时钟,感觉十分有意思,这里是地址:

http://www.eoeandroid.com/forum.php?mod=viewthread&tid=58324可惜的是这种方式没有

秒表。笔者突然对其有了兴趣,也想去实现以下自己的模拟时钟。折腾了一阵子总算是弄出来了

现在将实现方式共享出来,大家一些交流。

不多说,先上效果图:

Android实现模拟时钟(简单+漂亮)--时针、分针、秒针

Android实现模拟时钟(简单+漂亮)--时针、分针、秒针

准备工作

首先我们应该准备相关的素材:时钟盘、时针、分针、秒针图片.

时钟盘:

Android实现模拟时钟(简单+漂亮)--时针、分针、秒针

时针:

分针:

秒针:

源码部分

配置文件,比较简单:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="fill_parent"    android:layout_height="fill_parent"    android:orientation="vertical"    tools:context=".MainActivity"    android:background="@color/bg">    <com.kiritor.mymodelclock.MyQAnalogClock        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_gravity="center"            /></LinearLayout>

MyQAnalogClock代码:用于构造时钟view以及其刷新显示:

package com.kiritor.mymodelclock;import android.util.AttributeSet;import com.kiritor.mymodelclock.R;import android.content.Context;import android.graphics.*;import android.graphics.drawable.BitmapDrawable;import android.os.Handler;import android.view.View;import java.util.Calendar;import java.util.TimeZone;/** * Created by Kiritor on 13-5-30. */public class MyQAnalogClock extends View {    //时钟盘,分针、秒针、时针对象    Bitmap mBmpDial;    Bitmap mBmpHour;    Bitmap mBmpMinute;    Bitmap mBmpSecond;    BitmapDrawable bmdHour;    BitmapDrawable bmdMinute;    BitmapDrawable bmdSecond;    BitmapDrawable bmdDial;    Paint mPaint;    Handler tickHandler;    int mWidth;    int mHeigh;    int mTempWidth = bmdSecond.getIntrinsicWidth();    int mTempHeigh;    int centerX;    int centerY;    int availableWidth = 100;    int availableHeight = 100;    private String sTimeZoneString;    public MyQAnalogClock(Context context,AttributeSet attr)    {       this(context,"GMT+8:00");    }    public MyQAnalogClock(Context context, String sTime_Zone) {        super(context);        sTimeZoneString = sTime_Zone;        mBmpHour = BitmapFactory.decodeResource(getResources(),                R.drawable.shizhen);        bmdHour = new BitmapDrawable(mBmpHour);        mBmpMinute = BitmapFactory.decodeResource(getResources(),                R.drawable.fenzhen);        bmdMinute = new BitmapDrawable(mBmpMinute);        mBmpSecond = BitmapFactory.decodeResource(getResources(),                R.drawable.miaozhen);        bmdSecond = new BitmapDrawable(mBmpSecond);        mBmpDial = BitmapFactory.decodeResource(getResources(),                R.drawable.android_clock_dial);        bmdDial = new BitmapDrawable(mBmpDial);        mWidth = mBmpDial.getWidth();        mHeigh = mBmpDial.getHeight();        centerX = availableWidth / 2;        centerY = availableHeight / 2;        mPaint = new Paint();        mPaint.setColor(Color.BLUE);        run();    }    public void run() {        tickHandler = new Handler();        tickHandler.post(tickRunnable);    }    private Runnable tickRunnable = new Runnable() {        public void run() {            postInvalidate();            tickHandler.postDelayed(tickRunnable, 1000);        }    };    protected void onDraw(Canvas canvas) {        super.onDraw(canvas);        Calendar cal = Calendar.getInstance(TimeZone                .getTimeZone(sTimeZoneString));        int hour = cal.get(Calendar.HOUR);        int minute = cal.get(Calendar.MINUTE);        int second = cal.get(Calendar.SECOND);        float hourRotate = hour * 30.0f + minute / 60.0f * 30.0f;        float minuteRotate = minute * 6.0f;        float secondRotate = second * 6.0f;        boolean scaled = false;        if (availableWidth < mWidth || availableHeight < mHeigh) {            scaled = true;            float scale = Math.min((float) availableWidth / (float) mWidth,                    (float) availableHeight / (float) mHeigh);            canvas.save();            canvas.scale(scale, scale, centerX, centerY);        }        bmdDial.setBounds(centerX - (mWidth / 2), centerY - (mHeigh / 2),                centerX + (mWidth / 2), centerY + (mHeigh / 2));        bmdDial.draw(canvas);        mTempWidth = bmdHour.getIntrinsicWidth();        mTempHeigh = bmdHour.getIntrinsicHeight();        canvas.save();        canvas.rotate(hourRotate, centerX, centerY);        bmdHour.setBounds(centerX - (mTempWidth / 2), centerY                - (mTempHeigh / 2), centerX + (mTempWidth / 2), centerY                + (mTempHeigh / 2));        bmdHour.draw(canvas);        canvas.restore();        mTempWidth = bmdMinute.getIntrinsicWidth();        mTempHeigh = bmdMinute.getIntrinsicHeight();        canvas.save();        canvas.rotate(minuteRotate, centerX, centerY);        bmdMinute.setBounds(centerX - (mTempWidth / 2), centerY                - (mTempHeigh / 2), centerX + (mTempWidth / 2), centerY                + (mTempHeigh / 2));        bmdMinute.draw(canvas);        canvas.restore();        mTempWidth = bmdSecond.getIntrinsicWidth();        mTempHeigh = bmdSecond.getIntrinsicHeight();        canvas.rotate(secondRotate, centerX, centerY);        bmdSecond.setBounds(centerX - (mTempWidth / 2), centerY                - (mTempHeigh / 2), centerX + (mTempWidth / 2), centerY                + (mTempHeigh / 2));        bmdSecond.draw(canvas);        if (scaled) {            canvas.restore();        }    }}

主Activity:

package com.kiritor.mymodelclock;import android.app.Activity;import android.os.Bundle;/** * Created by Kiritor on 13-5-30. */public class MainActivity extends Activity {    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);    }}

好了一个简单的模拟时钟就完成了,不过通过观察运行效果可以看出的是,笔者对

时针、分针、秒针图片的设计不是太美观,看的不是太清楚,体验略差。不过这不是重点

读者可以自己去设计一下那4张图片,从而做出不同的效果!

这里本实例使用Android Studio做的,完整项目源码就不上传了!Over!



更多相关文章

  1. Android Widget小组件开发(一)——Android实现时钟Widget组件的步
  2. Android新手入门实例之Android漂亮时钟的源代码
  3. android 时钟组件AnalogClock与Clock
  4. android 小米时钟的实现
  5. android 在调用执行了reboot系统层做部分针对平台进行特殊处理
  6. android 实现时钟的简单方法
  7. android闹钟(三):实现时钟功能
  8. Qt仿Android带特效的数字时钟源码分析(滑动,翻页,旋转效果)
  9. 自定义Android时钟(支持秒针)

随机推荐

  1. android 通过http访问服务器数据
  2. android之mina框架通信学习
  3. 成佩涛编程之路——android之jquery使用(
  4. ubuntu环境下android开发平台的搭建
  5. Android读书笔记0-从零开始
  6. 【译】Android中构建快速可靠的UI测试
  7. 【Android(安卓)Studio快捷键】之代码提
  8. Android adb命令
  9. Android中的Cursor
  10. android reboot 功能的添加