首先看一下效果图,

下面看代码:

  1. /**
  2. *
  3. */
  4. package com.example.batterydemo;
  5. import android.content.Context;
  6. import android.graphics.Canvas;
  7. import android.graphics.Color;
  8. import android.graphics.Paint;
  9. import android.graphics.Paint.Style;
  10. import android.graphics.RectF;
  11. import android.util.AttributeSet;
  12. import android.view.View;
  13. /**
  14. * @author kince
  15. * @category 自定义View电池
  16. * @time 2014.2.13
  17. * @qq 543781062
  18. *
  19. */
  20. public class BatteryView extends View {
  21. /**
  22. * 画笔信息
  23. */
  24. private Paint mBatteryPaint;
  25. private Paint mPowerPaint;
  26. private float mBatteryStroke = 2f;
  27. /**
  28. * 屏幕高宽
  29. */
  30. private int measureWidth;
  31. private int measureHeigth;
  32. /**
  33. *
  34. * 电池参数
  35. */
  36. private float mBatteryHeight = 30f; // 电池的高度
  37. private float mBatteryWidth = 60f; // 电池的宽度
  38. private float mCapHeight = 15f;
  39. private float mCapWidth = 5f;
  40. /**
  41. *
  42. * 电池电量
  43. */
  44. private float mPowerPadding = 1;
  45. private float mPowerHeight = mBatteryHeight - mBatteryStroke
  46. - mPowerPadding * 2; // 电池身体的高度
  47. private float mPowerWidth = mBatteryWidth - mBatteryStroke - mPowerPadding
  48. * 2;// 电池身体的总宽度
  49. private float mPower = 0f;
  50. /**
  51. *
  52. * 矩形
  53. */
  54. private RectF mBatteryRect;
  55. private RectF mCapRect;
  56. private RectF mPowerRect;
  57. public BatteryView(Context context) {
  58. super(context);
  59. initView();
  60. }
  61. public BatteryView(Context context, AttributeSet attrs) {
  62. super(context, attrs);
  63. initView();
  64. }
  65. public BatteryView(Context context, AttributeSet attrs, int defStyleAttr) {
  66. super(context, attrs, defStyleAttr);
  67. initView();
  68. }
  69. public void initView() {
  70. /**
  71. * 设置电池画笔
  72. */
  73. mBatteryPaint = new Paint();
  74. mBatteryPaint.setColor(Color.GRAY);
  75. mBatteryPaint.setAntiAlias(true);
  76. mBatteryPaint.setStyle(Style.STROKE);
  77. mBatteryPaint.setStrokeWidth(mBatteryStroke);
  78. /**
  79. * 设置电量画笔
  80. */
  81. mPowerPaint = new Paint();
  82. mPowerPaint.setColor(Color.RED);
  83. mPowerPaint.setAntiAlias(true);
  84. mPowerPaint.setStyle(Style.FILL);
  85. mPowerPaint.setStrokeWidth(mBatteryStroke);
  86. /**
  87. * 设置电池矩形
  88. */
  89. mBatteryRect = new RectF(mCapWidth, 0, mBatteryWidth, mBatteryHeight);
  90. /**
  91. * 设置电池盖矩形
  92. */
  93. mCapRect = new RectF(0, (mBatteryHeight - mCapHeight) / 2, mCapWidth,
  94. (mBatteryHeight - mCapHeight) / 2 + mCapHeight);
  95. /**
  96. * 设置电量矩形
  97. */
  98. mPowerRect = new RectF(mCapWidth + mBatteryStroke / 2 + mPowerPadding
  99. + mPowerWidth * ((100f - mPower) / 100f), // 需要调整左边的位置
  100. mPowerPadding + mBatteryStroke / 2, // 需要考虑到 画笔的宽度
  101. mBatteryWidth - mPowerPadding * 2, mBatteryStroke / 2
  102. + mPowerPadding + mPowerHeight);
  103. }
  104. @Override
  105. protected void onDraw(Canvas canvas) {
  106. super.onDraw(canvas);
  107. canvas.save();
  108. canvas.translate(measureWidth / 2, measureHeigth / 2);
  109. canvas.drawRoundRect(mBatteryRect, 2f, 2f, mBatteryPaint); // 画电池轮廓需要考虑 画笔的宽度
  110. canvas.drawRoundRect(mCapRect, 2f, 2f, mBatteryPaint);// 画电池盖
  111. canvas.drawRect(mPowerRect, mPowerPaint);// 画电量
  112. canvas.restore();
  113. }
  114. @Override
  115. protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  116. measureWidth = MeasureSpec.getSize(widthMeasureSpec);
  117. measureHeigth = MeasureSpec.getSize(heightMeasureSpec);
  118. setMeasuredDimension(measureWidth, measureHeigth);
  119. }
  120. /**]
  121. * @category 设置电池电量
  122. * @param power
  123. */
  124. public void setPower(float power) {
  125. mPower = power;
  126. if (mPower < 0) {
  127. mPower = 0;
  128. }
  129. mPowerRect = new RectF(mCapWidth + mBatteryStroke / 2 + mPowerPadding
  130. + mPowerWidth * ((100f - mPower) / 100f), // 需要调整左边的位置
  131. mPowerPadding + mBatteryStroke / 2, // 需要考虑到 画笔的宽度
  132. mBatteryWidth - mPowerPadding * 2, mBatteryStroke / 2
  133. + mPowerPadding + mPowerHeight);
  134. invalidate();
  135. }
  136. }

代码已经注释得比较清楚了,大家自己看吧,不懂的方法可以去看一下api。

Android 自定义UI--电池的更多相关文章

  1. android自定义UI模板图文详解

    不知道大家在实际开发中有没有自定义过UI模板?今天花时间研究了一下android中自定义UI模板,与大家分享一下. 每个设计良好的App都是自定义标题栏,在自定义标题栏的过程中大部分人可能都是自定义一 ...

  2. Android自定义UI的实现和应用

    在Android项目开发中,不可避免的要遇到自定义的UI,用较好的体验去讨好UED妹子和交互设计师手下留情~几个迭代下来,遇到了不少这样的要求,有简单有复杂.最好的实现方案就是讲业务和UI隔离,封装成 ...

  3. Android自定义UI模板

    第一步:自定义xml属性 新建一个android项目,在values文件夹中新建一个atts.xml的文件,在这个xml文件中声明我们一会在使用自定义控件时候需要指明的属性.atts.xml < ...

  4. android自定义View之NotePad出鞘记

    现在我们的手机上基本都会有一个记事本,用起来倒也还算方便,记事本这种东东,如果我想要自己实现,该怎么做呢?今天我们就通过自定义View的方式来自定义一个记事本.OK,废话不多说,先来看看效果图. 整个 ...

  5. Android开源的精美日历控件,热插拔设计的万能自定义UI

    Android开源的精美日历控件,热插拔设计的万能自定义UI UI框架应该逻辑与界面实现分离,该日历控件使用了热插拔的设计 ,简单几步即可实现你需要的UI效果,热插拔的思想是你提供你的实现,我提供我的 ...

  6. Android自定义View和控件之一-定制属于自己的UI

    照例,拿来主义.我的学习是基于下面的三篇blog.前两是基本的流程,第三篇里有比较细致的绘制相关的属性.第4篇介绍了如何减少布局层次来提高效率. 1. 教你搞定Android自定义View 2. 教你 ...

  7. Android自定义View 画弧形,文字,并增加动画效果

    一个简单的Android自定义View的demo,画弧形,文字,开启一个多线程更新ui界面,在子线程更新ui是不允许的,但是View提供了方法,让我们来了解下吧. 1.封装一个抽象的View类   B ...

  8. Android 自定义View合集

    自定义控件学习 https://github.com/GcsSloop/AndroidNote/tree/master/CustomView 小良自定义控件合集 https://github.com/ ...

  9. Android 自定义View (五)——实践

    前言: 前面已经介绍了<Android 自定义 view(四)-- onMeasure 方法理解>,那么这次我们就来小实践下吧 任务: 公司现有两个任务需要我完成 (1)监测液化天然气液压 ...

  10. [原] Android 自定义View步骤

    例子如下:Android 自定义View 密码框 例子 1 良好的自定义View 易用,标准,开放. 一个设计良好的自定义view和其他设计良好的类很像.封装了某个具有易用性接口的功能组合,这些功能能 ...

随机推荐

  1. 【转】 LINQ To SQL 语法及实例大全

    LINQ to SQL语句(1)之Where Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子 ...

  2. mybatis的简单使用

    使用mybatis数据库时,需要添加一下jar包: asm-3.3.1.jarcglib-2.2.2.jarjavassist-3.17.1-GA.jarlog4j-1.2.17.jarmybatis ...

  3. (转)使用 .NET 的 RNGCryptoServiceProvider 生成随机数

    1. [代码]一个简单的方法,但不够可靠     跳至 [1] [2] [全屏预览] ? 1 2 3 4 5 6 7 8 9 10 11 static void Main(string[] args) ...

  4. 委托与Lambda-浅谈

    委托概述 委托是寻址方法的.NET版本. 在C++中,函数指针只不过是一个指向内存位置的指针,它不是类型安全的.我们无法判断这个指针实际指向什么,更不知晓像参数和返回类型等项了. 而.NET委托完全不 ...

  5. tomcat 远程 调试 eclipse

    windows系统: 修改catalina.bat   端口9000 SET CATALINA_OPTS=-server -Xdebug -Xnoagent -Djava.compiler=NONE ...

  6. spring 配置文件 引入外部的property文件的两种方法

    spring  的配置文件 引入外部的property文件的两种方法 <!-- 引入jdbc配置文件    方法一 --> <bean id="propertyConfig ...

  7. JS nodeType返回类型(复制的

    http://blog.csdn.net/qyf_5445/article/details/9232907 将HTML DOM中几个容易常用的属性做下记录: nodeName.nodeValue 以及 ...

  8. 在TCP协议下的数据传送

    本人小白菜逼一枚,,,,刚建立博客,也写不了太深入的,就写点上课的笔记什么的.有错误希望广大博友指出,我一定虚心学习接收改正. 我的新浪邮箱:liudaohui0805@sina.com 我的QQ邮箱 ...

  9. Ghost克隆软件

    克隆软件Ghost初级使用教程 一.什么是Ghost ? Ghost(幽灵)软件是美国赛门铁克公司推出的一款出色的硬盘备份还原工具,可以实现FAT16.FAT32.NTFS.OS2等多种硬盘分区格式的 ...

  10. 前端技术-svg简介与snap.svg.js开源项目的使用

    前言-为什么学习snap.svg.js 前阵子webAPP的技术群里有人感觉到svg+animate的形式感觉很炫,矢量图任意放大且不需要下载图片,并且在手机端效果流畅. (矢量图与位图最大的区别是, ...