Android 自定义UI--电池
首先看一下效果图,
下面看代码:
- /**
- *
- */
- package com.example.batterydemo;
- import android.content.Context;
- import android.graphics.Canvas;
- import android.graphics.Color;
- import android.graphics.Paint;
- import android.graphics.Paint.Style;
- import android.graphics.RectF;
- import android.util.AttributeSet;
- import android.view.View;
- /**
- * @author kince
- * @category 自定义View电池
- * @time 2014.2.13
- * @qq 543781062
- *
- */
- public class BatteryView extends View {
- /**
- * 画笔信息
- */
- private Paint mBatteryPaint;
- private Paint mPowerPaint;
- private float mBatteryStroke = 2f;
- /**
- * 屏幕高宽
- */
- private int measureWidth;
- private int measureHeigth;
- /**
- *
- * 电池参数
- */
- private float mBatteryHeight = 30f; // 电池的高度
- private float mBatteryWidth = 60f; // 电池的宽度
- private float mCapHeight = 15f;
- private float mCapWidth = 5f;
- /**
- *
- * 电池电量
- */
- private float mPowerPadding = 1;
- private float mPowerHeight = mBatteryHeight - mBatteryStroke
- - mPowerPadding * 2; // 电池身体的高度
- private float mPowerWidth = mBatteryWidth - mBatteryStroke - mPowerPadding
- * 2;// 电池身体的总宽度
- private float mPower = 0f;
- /**
- *
- * 矩形
- */
- private RectF mBatteryRect;
- private RectF mCapRect;
- private RectF mPowerRect;
- public BatteryView(Context context) {
- super(context);
- initView();
- }
- public BatteryView(Context context, AttributeSet attrs) {
- super(context, attrs);
- initView();
- }
- public BatteryView(Context context, AttributeSet attrs, int defStyleAttr) {
- super(context, attrs, defStyleAttr);
- initView();
- }
- public void initView() {
- /**
- * 设置电池画笔
- */
- mBatteryPaint = new Paint();
- mBatteryPaint.setColor(Color.GRAY);
- mBatteryPaint.setAntiAlias(true);
- mBatteryPaint.setStyle(Style.STROKE);
- mBatteryPaint.setStrokeWidth(mBatteryStroke);
- /**
- * 设置电量画笔
- */
- mPowerPaint = new Paint();
- mPowerPaint.setColor(Color.RED);
- mPowerPaint.setAntiAlias(true);
- mPowerPaint.setStyle(Style.FILL);
- mPowerPaint.setStrokeWidth(mBatteryStroke);
- /**
- * 设置电池矩形
- */
- mBatteryRect = new RectF(mCapWidth, 0, mBatteryWidth, mBatteryHeight);
- /**
- * 设置电池盖矩形
- */
- mCapRect = new RectF(0, (mBatteryHeight - mCapHeight) / 2, mCapWidth,
- (mBatteryHeight - mCapHeight) / 2 + mCapHeight);
- /**
- * 设置电量矩形
- */
- mPowerRect = new RectF(mCapWidth + mBatteryStroke / 2 + mPowerPadding
- + mPowerWidth * ((100f - mPower) / 100f), // 需要调整左边的位置
- mPowerPadding + mBatteryStroke / 2, // 需要考虑到 画笔的宽度
- mBatteryWidth - mPowerPadding * 2, mBatteryStroke / 2
- + mPowerPadding + mPowerHeight);
- }
- @Override
- protected void onDraw(Canvas canvas) {
- super.onDraw(canvas);
- canvas.save();
- canvas.translate(measureWidth / 2, measureHeigth / 2);
- canvas.drawRoundRect(mBatteryRect, 2f, 2f, mBatteryPaint); // 画电池轮廓需要考虑 画笔的宽度
- canvas.drawRoundRect(mCapRect, 2f, 2f, mBatteryPaint);// 画电池盖
- canvas.drawRect(mPowerRect, mPowerPaint);// 画电量
- canvas.restore();
- }
- @Override
- protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
- measureWidth = MeasureSpec.getSize(widthMeasureSpec);
- measureHeigth = MeasureSpec.getSize(heightMeasureSpec);
- setMeasuredDimension(measureWidth, measureHeigth);
- }
- /**]
- * @category 设置电池电量
- * @param power
- */
- public void setPower(float power) {
- mPower = power;
- if (mPower < 0) {
- mPower = 0;
- }
- mPowerRect = new RectF(mCapWidth + mBatteryStroke / 2 + mPowerPadding
- + mPowerWidth * ((100f - mPower) / 100f), // 需要调整左边的位置
- mPowerPadding + mBatteryStroke / 2, // 需要考虑到 画笔的宽度
- mBatteryWidth - mPowerPadding * 2, mBatteryStroke / 2
- + mPowerPadding + mPowerHeight);
- invalidate();
- }
- }
代码已经注释得比较清楚了,大家自己看吧,不懂的方法可以去看一下api。
Android 自定义UI--电池的更多相关文章
- android自定义UI模板图文详解
不知道大家在实际开发中有没有自定义过UI模板?今天花时间研究了一下android中自定义UI模板,与大家分享一下. 每个设计良好的App都是自定义标题栏,在自定义标题栏的过程中大部分人可能都是自定义一 ...
- Android自定义UI的实现和应用
在Android项目开发中,不可避免的要遇到自定义的UI,用较好的体验去讨好UED妹子和交互设计师手下留情~几个迭代下来,遇到了不少这样的要求,有简单有复杂.最好的实现方案就是讲业务和UI隔离,封装成 ...
- Android自定义UI模板
第一步:自定义xml属性 新建一个android项目,在values文件夹中新建一个atts.xml的文件,在这个xml文件中声明我们一会在使用自定义控件时候需要指明的属性.atts.xml < ...
- android自定义View之NotePad出鞘记
现在我们的手机上基本都会有一个记事本,用起来倒也还算方便,记事本这种东东,如果我想要自己实现,该怎么做呢?今天我们就通过自定义View的方式来自定义一个记事本.OK,废话不多说,先来看看效果图. 整个 ...
- Android开源的精美日历控件,热插拔设计的万能自定义UI
Android开源的精美日历控件,热插拔设计的万能自定义UI UI框架应该逻辑与界面实现分离,该日历控件使用了热插拔的设计 ,简单几步即可实现你需要的UI效果,热插拔的思想是你提供你的实现,我提供我的 ...
- Android自定义View和控件之一-定制属于自己的UI
照例,拿来主义.我的学习是基于下面的三篇blog.前两是基本的流程,第三篇里有比较细致的绘制相关的属性.第4篇介绍了如何减少布局层次来提高效率. 1. 教你搞定Android自定义View 2. 教你 ...
- Android自定义View 画弧形,文字,并增加动画效果
一个简单的Android自定义View的demo,画弧形,文字,开启一个多线程更新ui界面,在子线程更新ui是不允许的,但是View提供了方法,让我们来了解下吧. 1.封装一个抽象的View类 B ...
- Android 自定义View合集
自定义控件学习 https://github.com/GcsSloop/AndroidNote/tree/master/CustomView 小良自定义控件合集 https://github.com/ ...
- Android 自定义View (五)——实践
前言: 前面已经介绍了<Android 自定义 view(四)-- onMeasure 方法理解>,那么这次我们就来小实践下吧 任务: 公司现有两个任务需要我完成 (1)监测液化天然气液压 ...
- [原] Android 自定义View步骤
例子如下:Android 自定义View 密码框 例子 1 良好的自定义View 易用,标准,开放. 一个设计良好的自定义view和其他设计良好的类很像.封装了某个具有易用性接口的功能组合,这些功能能 ...
随机推荐
- JavaScript的68个技巧一
1. 严格模式 在自己的项目中 你可以坚持只使用" 严格模式 " 或只使用" 非严格模式 "的策略.但如果你要编写健壮的代码应对各种各样的代码连接 你有两个可选 ...
- JAVA内存区域和GC机制
目录 Java垃圾回收概况 Java内存区域 Java对象的访问方式 Java内存分配机制 Java GC机制 垃圾收集器 Java垃圾回收概况 Java GC(Garbage Collection, ...
- Linux命令初步了解
知识点: 1.虚拟控制台: 在系统启动时直接进入字符工作方式后,系统提供了多个(默认为6个)虚拟控制台.每个虚拟控制台可以相互独立使用,互不影响. 可以使用Alt+F1~Alt+F6进行多个虚拟控制台 ...
- 小学生之KTV播放原理
第一步: 创建一个Song类 //歌曲名称 public string SongName { get; set; } //歌曲路劲 public string SongPath { get; set ...
- iframe顶部跳转跨域问题
$("#button").on("click", function () { // top.location.locatio ...
- html 页面实现指定位置的跳转
1.同页面跳转到相应位置 <a href="#id1">跳转到词条1</a> <a href="#id2">跳转到词条2&l ...
- JS将毫秒转换成时间格式
JavaScript Date(日期)对象 实例 getTime():返回从 1970 年 1 月 1 日至今的毫秒数. setFullYear(): 设置具体的日期. toUTCString():将 ...
- .attr()和.prop()和.css()的区别
是不是新手都会遇到这个问题?遇到过一次,在网上搜一搜,综合成了下面这样.重点参考了dolphin的‘jQuery的attr与prop’, 写的很清楚呢. 一般attribute翻译成中文术语为“特性” ...
- ECSTORE2.0 新增自定义定时任务
在ECsotre系统里面添加一个自定义的定时任务,可以完成一些自动化处理,例如自动确认订单或者是删除无效订单的,可以很方便的实现各种定时执行的任务,下面简单介绍下怎么添加定时任务. 在自己的app目录 ...
- POJ2406 KMP算法
POJ2406 问题重述:给定字符串s0,记连续的k个s前后相连组成的s0s0...s0为s0^k.输入字符串S,求最大的k,使得S = s0^k. 问题分析: 1.采用kmp算法求出前缀函数 pre ...