Android-自定义控件之时针-霞辉
注释已经比较详细了,废话就不多说了。贴代码了
时针分针秒钟都做上去了,采用的方法也很简单,仔细看一会就能看懂
自定义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-自定义控件之时针-霞辉的更多相关文章
- Android getAttributeIntValue()详解-霞辉
经常使用getAttributeIntValue()方法,但是大多使用的形式是attrs.getAttributeFloatValue(null, "xxx", 0);只是在中间传 ...
- Android自定义控件之自定义ViewGroup实现标签云
前言: 前面几篇讲了自定义控件绘制原理Android自定义控件之基本原理(一),自定义属性Android自定义控件之自定义属性(二),自定义组合控件Android自定义控件之自定义组合控件(三),常言 ...
- Android自定义控件之自定义组合控件
前言: 前两篇介绍了自定义控件的基础原理Android自定义控件之基本原理(一).自定义属性Android自定义控件之自定义属性(二).今天重点介绍一下如何通过自定义组合控件来提高布局的复用,降低开发 ...
- Android自定义控件之自定义属性
前言: 上篇介绍了自定义控件的基本要求以及绘制的基本原理,本篇文章主要介绍如何给自定义控件自定义一些属性.本篇文章将继续以上篇文章自定义圆形百分比为例进行讲解.有关原理知识请参考Android自定义控 ...
- Android自定义控件之基本原理
前言: 在日常的Android开发中会经常和控件打交道,有时Android提供的控件未必能满足业务的需求,这个时候就需要我们实现自定义一些控件,今天先大致了解一下自定义控件的要求和实现的基本原理. 自 ...
- Android自定义控件1
概述 Android已经为我们提供了大量的View供我们使用,但是可能有时候这些组件不能满足我们的需求,这时候就需要自定义控件了.自定义控件对于初学者总是感觉是一种复杂的技术.因为里面涉及到的知识点会 ...
- 一起来学习Android自定义控件1
概述 Android已经为我们提供了大量的View供我们使用,但是可能有时候这些组件不能满足我们的需求,这时候就需要自定义控件了.自定义控件对于初学者总是感觉是一种复杂的技术.因为里面涉及到的知识点会 ...
- [Xamarin.Android] 自定义控件
[Xamarin.Android] 自定义控件 前言 软件项目开发的过程中,免不了遇到一些无法使用内建控件就能满足的客户需求,例如:时速表.折线图...等等.这时开发人员可以透过自定义控件的方式,为项 ...
- android自定义控件实现TextView按下后字体颜色改变
今天跟大家分享一下Android自定义控件入门,先介绍一个简单的效果TextView,按下改变字体颜色,后期慢慢扩展更强大的功能 直接看图片 第一张是按下后截的图,功能很简单, ...
随机推荐
- TV端:通过遥控器的点击实现图片的上下左右抖动的效果
做TV端有一段时间了,我看到别的TV上有一个通过遥控器的触摸板来控制一张图片的相应方向的抖动,感觉听新奇的,就试着做了一个分享一下: 转载注明出处:http://www.cnblogs.com/hyy ...
- .NET中代理服务器WebProxy的各种用法
引用地址 引用 因为涉及到代理的各种情况,WebRequest和WebProxy类的文档写的相当复杂,不但各个文档关注点不同,而且不同版本的同一文档也有小小的区别,网上也没有关于这个类的相关文章.于是 ...
- HTML5 技术在风电、光伏等新能源领域的应用
随着新一轮工业革命兴起,应对气候变化日益成为全球共识,能源技术正在成为引领能源产业变革.实现创新驱动发展的源动力.从全球到中国,以风能.光伏发电为代表的新能源产业发展迅速,可再生能源发电与现代电网的融 ...
- iOS Plist 文件的 增 删 改
一:Plist 文件的创建 Plist 文件作为我们IOS开发的一种数据存储文件,还是经常会用到的.在看<X-code江湖录>的时候,看到了这一点.自己就写了一下,把写的东西分享出来!先看 ...
- LVS的十种调度算法
LVS十种调度算法 1.静态调度: ①rr(Round Robin):轮询调度,轮叫调度 轮询调度算法的原理是每一次把来自用户的请求轮流分配给内部中的服务器,从1开始,直到N(内部服务器个数),然后重 ...
- (二) 从Angular1到Angular2需要的预备知识
1. TypeScript语法与ES6新特性 写惯了jQ的话突然从ES5跳到ES6,又是个变形的ES6(TypeScript),学习成本确实不低.不过笔者也是从ng1直接上手ng2,对与很多新特性的积 ...
- [bzoj1067][SCOI2007]降雨量——线段树+乱搞
题目大意 传送门 题解 我国古代有一句俗话. 骗分出奇迹,乱搞最神奇! 这句话在这道题上得到了鲜明的体现. 我的方法就是魔改版线段树,乱搞搞一下,首先借鉴了黄学长的建树方法,直接用一个节点维护年份的区 ...
- Zabbix简介及安装
前言 未经监控就上线的系统,就是裸奔,耍流氓. 监控对我们来说太重要了,监控工具也有很多,像,Cacti,Nagios,Ganglia,Zabbix等等,今天我们要介绍的是Zabbix,它的功能很强大 ...
- webstorm下的sass自动编译和移动端自适应实践
1.安装Ruby 2.安装sass 3.webstorm配置file watcher 4.移动端自适应 1.安装Ruby 安装Ruby,有多种方式,打开官网下载 因为,使用的是window选择Ruby ...
- 原来JS是这样的 - 提升, 作用域 与 闭包
引子 长久以来一直都没有专门学过 JS ,因为之前有自己啃过 C++ ,又打过一段时间的算法竞赛(写得一手好意大利面条),于是自己折腾自己的网站的时候,一直都把 JS 当 C 写.但写的时候总会遇到一 ...