注释已经比较详细了,废话就不多说了。贴代码了

时针分针秒钟都做上去了,采用的方法也很简单,仔细看一会就能看懂

自定义View类

package com.xh.mytime;

import java.util.Calendar;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.Rect;
import android.os.Handler;
import android.util.AttributeSet;
import android.view.View;

public class MyTimeTest extends View implements Runnable
{
private int srcId;
private int fensize;
private int shisize;
private int miaosize;
private Bitmap bitmap;
private float guimo;
private float wzhong;
private float hzhong;

private Handler handler = new Handler();

/*
* */
public MyTimeTest(Context context, AttributeSet attrs)
{
super(context, attrs);
// 读取相应的属性值
//在布局文件中定义了这样的一个属性,取得它的属性值,该属性值指向一张图片,通过bitmapFactory获得由它制定的图片bitmap
srcId = attrs.getAttributeResourceValue(null,
"Src", 0);
if (srcId > 0)
bitmap = BitmapFactory.decodeResource(getResources(),
srcId);

guimo = attrs.getAttributeFloatValue(null, "scale", 1);
//获取xml文件中的图片宽度中点,如果没有设置则说明图片是对称的。取默认返回参数
wzhong = attrs.getAttributeFloatValue(null,
"wzhong", bitmap.getWidth() / 2);
//获取xml文件中的图片高度中点,如果没有设置则说明图片是对称的。取默认返回参数
hzhong = attrs.getAttributeFloatValue(null,
"hzhong", bitmap.getHeight() / 2);
//获取到时针和分针的大小
fensize = (int) (attrs.getAttributeIntValue(null,
"fensize", 0));
shisize = (int) (attrs.getAttributeIntValue(null, "shisize",
0));
miaosize = (int)(attrs.getAttributeIntValue(null, "miaosize", 0));


}
//刷新,保证能接受到每一次view的变化.
@Override
public void run()
{
// 重新绘制View
invalidate();

handler.postDelayed(this, 1000);
}

//如果不覆盖此方法,默认的会将view铺满整个屏幕
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
{
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
// 根据图像的实际大小等比例设置View的大小
setMeasuredDimension((int) (bitmap.getWidth() * guimo), (int) (bitmap
.getHeight() * guimo));
}

@Override
protected void onDraw(Canvas canvas)
{
super.onDraw(canvas);
//笔
Paint paint = new Paint();
//矩形
Rect src = new Rect();
Rect target = new Rect();

src.left = 0;
src.top = 0;
src.right = bitmap.getWidth();
src.bottom = bitmap.getHeight();

target.left = 0;
target.top = 0;
target.bottom = (int) (src.bottom * guimo);
target.right = (int) (src.right * guimo);
// 画表盘图像
/*
* dai
* */
canvas.drawBitmap(bitmap, src, target, paint);
// 计算表盘中心点的横纵坐标
float centerX = bitmap.getWidth() * guimo * wzhong;
float centerY = bitmap.getHeight() * guimo * hzhong;
// 表表盘中心点画一个半径为5的实心圆圈
canvas.drawCircle(centerX, centerY, 5, paint);




Calendar calendar = Calendar.getInstance();

int currentMinute = calendar.get(Calendar.MINUTE);
int currentHour = calendar.get(Calendar.HOUR);
int currentsec = calendar.get(Calendar.SECOND);
// 计算分针和时间的角度

double hourRadian = Math.toRadians(
(360 - ((currentHour * 30) - 90))% 360 - (30 * currentMinute / 60)
);

double minuteRadian = Math.toRadians(
(360 - ((currentMinute * 6) - 90)) % 360
);
double secRadian = Math.toRadians(
(360 - ((currentsec * 6) - 90))% 360
);
// 在表盘上画分针

paint.setStrokeWidth(6);
// 在表盘上画分针
canvas.drawLine(centerX, centerY, (int) (centerX + shisize
* Math.cos(hourRadian)), (int) (centerY - shisize
* Math.sin(hourRadian)), paint);
paint.setStrokeWidth(5);

canvas.drawLine(centerX, centerY, (int) (centerX + fensize
* Math.cos(minuteRadian)), (int) (centerY - fensize
* Math.sin(minuteRadian)), paint);
// 设置实针为4个象素粗

paint.setStrokeWidth(4);
canvas.drawLine(centerX, centerY, (int) (centerX + miaosize
* Math.cos(secRadian)), (int) (centerY - miaosize
* Math.sin(secRadian)), paint);

handler.postDelayed(this, 1000);
}

}

布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.xh.mytimetest.MainActivity"
android:orientation="vertical"
android:gravity="center">

<com.xh.mytime.MyTimeTest
android:id="@+id/myTimeTest2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
Src="@drawable/mytime"
hzhong="0.512"
wzhong="0.505"
shisize="65"
fensize="80"
guimo="0.75"
miaosize="95"
android:clickable="true"/>

</LinearLayout>

源代码上传,另外包含一个数字时针,点击可跳转

http://files.cnblogs.com/files/1124hui/MyTime.zip

Android-自定义控件之时针-霞辉的更多相关文章

  1. Android getAttributeIntValue()详解-霞辉

    经常使用getAttributeIntValue()方法,但是大多使用的形式是attrs.getAttributeFloatValue(null, "xxx", 0);只是在中间传 ...

  2. Android自定义控件之自定义ViewGroup实现标签云

    前言: 前面几篇讲了自定义控件绘制原理Android自定义控件之基本原理(一),自定义属性Android自定义控件之自定义属性(二),自定义组合控件Android自定义控件之自定义组合控件(三),常言 ...

  3. Android自定义控件之自定义组合控件

    前言: 前两篇介绍了自定义控件的基础原理Android自定义控件之基本原理(一).自定义属性Android自定义控件之自定义属性(二).今天重点介绍一下如何通过自定义组合控件来提高布局的复用,降低开发 ...

  4. Android自定义控件之自定义属性

    前言: 上篇介绍了自定义控件的基本要求以及绘制的基本原理,本篇文章主要介绍如何给自定义控件自定义一些属性.本篇文章将继续以上篇文章自定义圆形百分比为例进行讲解.有关原理知识请参考Android自定义控 ...

  5. Android自定义控件之基本原理

    前言: 在日常的Android开发中会经常和控件打交道,有时Android提供的控件未必能满足业务的需求,这个时候就需要我们实现自定义一些控件,今天先大致了解一下自定义控件的要求和实现的基本原理. 自 ...

  6. Android自定义控件1

    概述 Android已经为我们提供了大量的View供我们使用,但是可能有时候这些组件不能满足我们的需求,这时候就需要自定义控件了.自定义控件对于初学者总是感觉是一种复杂的技术.因为里面涉及到的知识点会 ...

  7. 一起来学习Android自定义控件1

    概述 Android已经为我们提供了大量的View供我们使用,但是可能有时候这些组件不能满足我们的需求,这时候就需要自定义控件了.自定义控件对于初学者总是感觉是一种复杂的技术.因为里面涉及到的知识点会 ...

  8. [Xamarin.Android] 自定义控件

    [Xamarin.Android] 自定义控件 前言 软件项目开发的过程中,免不了遇到一些无法使用内建控件就能满足的客户需求,例如:时速表.折线图...等等.这时开发人员可以透过自定义控件的方式,为项 ...

  9. android自定义控件实现TextView按下后字体颜色改变

    今天跟大家分享一下Android自定义控件入门,先介绍一个简单的效果TextView,按下改变字体颜色,后期慢慢扩展更强大的功能 直接看图片             第一张是按下后截的图,功能很简单, ...

随机推荐

  1. WebForm 内置对象、数据增删改、状态保持

    一.内置对象 1.Response对象:响应请求 Response.Write("<script>alert('添加成功!')</script>"); → ...

  2. datagridview数据绑定操作数据库实现增删改查

    DataSet数据集,数据缓存在客户端内存中,支持断开式连接.DataGridView控件绑定DataSet时,它自动的改变的DS的行的状态,而且在做增删改查的时候,可以借助SqlCommandBui ...

  3. 一篇文章搞定css3 3d效果

    css3 3d学习心得 卡片反转 魔方 banner图 首先我们要学习好css3 3d一定要有一定的立体感 通过这个图片应该清楚的了解到了x轴 y轴 z轴是什么概念了. 首先先给大家看一个小例子: 卡 ...

  4. linux系统盘使用率达到100%的问题查找和解决方法

    今天公司云服务器报警系统发来短信,系统磁盘空间不够,登录服务器进行查看,磁盘使用虑达到100%,       感觉比较奇怪,所存的东西并不多,怎么会将磁盘占满,而且数据都是存在数据盘下,通过简单的进行 ...

  5. WEB前端性能优化之一——网页级优化

    1.减少Http请求 http请求是指从客户端到服务器端的请求消息.其中包含对html.css.js.图片资源以及交互数据处理内容等.在前端性能网页级优化中较少http请求是非常重要的一块,每当我们提 ...

  6. javascript学习-目录

    Javascript学习 第1章 Javascript简介 1.1 Javascript简史 1.2 Javascript实现 1.3 Javascript版本 第2章 Javascript入门 2. ...

  7. JAVA中的数据结构 - 真正的去理解红黑树

    一, 红黑树所处数据结构的位置: 在JDK源码中, 有treeMap和JDK8的HashMap都用到了红黑树去存储 红黑树可以看成B树的一种: 从二叉树看,红黑树是一颗相对平衡的二叉树 二叉树--&g ...

  8. devexpress实现单元格根据条件显示不同的样式(颜色、字体、对齐方式,大小等)

    1.devexpress控件库之所以被大家所喜爱,是因为它将许多常用的东西都封装成了属性.可以通过一些简单的配置,将以前某些需要大篇幅代码才可实现的效果展示出来.这里是一个实现了将[第二列数据在表格0 ...

  9. Dijkstra算法——单源最短路径问题

    学习一个点到其余各个顶点的最短路径--单源最短路径 Dijkstra算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向 ...

  10. 关于fibonacci数列用JS写的一点小优化

    直接上代码 var month = prompt("请输入月数:") function fibobo(x) { //先定义一个已有前两项的数组,用来作缓存 var arr = [1 ...