如果你打算完全定制一个View,那么你需要实现View类(所有的Android View都实现于这个类),并且实现确定尺寸的onMeasure(…))方法和确认绘图的onDraw(…))方法。

自定义View一共分为6步

第一步


public class SmileyView extends View {private Paint mCirclePaint;private Paint mEyeAndMouthPaint;private float mCenterX;private float mCenterY;private float mRadius;private RectF mArcBounds = new RectF();public SmileyView(Context context) {this(context, null);}public SmileyView(Context context, AttributeSet attrs) {this(context, attrs, 0);}public SmileyView(Context context, AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);initPaints();}private void initPaints() {/* ... */}@Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {/* ... */}@Overrideprotected void onDraw(Canvas canvas) {/* ... */}
}

2.实现画笔paint类

本文一共两只画笔


private void initPaints() {mCirclePaint = new Paint(Paint.ANTI_ALIAS_FLAG);mCirclePaint.setStyle(Paint.Style.FILL);mCirclePaint.setColor(Color.YELLOW);mEyeAndMouthPaint = new Paint(Paint.ANTI_ALIAS_FLAG);mEyeAndMouthPaint.setStyle(Paint.Style.STROKE);mEyeAndMouthPaint.setStrokeWidth(16 * getResources().getDisplayMetrics().density);mEyeAndMouthPaint.setStrokeCap(Paint.Cap.ROUND);mEyeAndMouthPaint.setColor(Color.BLACK);
}

3.覆写onMeasure(…)方法

实现这个方法告诉了母容器如何放弃自定义View,可以通过提供的measureSpecs来决定你的View的高和宽,以下是一个正方形,确认它的宽和高是一样的。

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {int w = MeasureSpec.getSize(widthMeasureSpec);int h = MeasureSpec.getSize(heightMeasureSpec);int size = Math.min(w, h);setMeasuredDimension(size, size);
}

注意:

这个方法需要至少保证一个setMeasuredDimension(..)调用,否则会报IllegalStateException错误。

4.实现onSizeChanged(…)方法

这个方法是你获取View现在的宽和高. 这里我们计算的是中心和半径。

@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {mCenterX = w / 2f;mCenterY = h / 2f;mRadius = Math.min(w, h) / 2f;
}

5.实现onDraw(…)方法

这个方法提供了如何绘制view,它提供的Canvas类可以进行绘制。

@Override
protected void onDraw(Canvas canvas) {// draw facecanvas.drawCircle(mCenterX, mCenterY, mRadius, mCirclePaint);// draw eyesfloat eyeRadius = mRadius / 5f;float eyeOffsetX = mRadius / 3f;float eyeOffsetY = mRadius / 3f;canvas.drawCircle(mCenterX - eyeOffsetX, mCenterY - eyeOffsetY, eyeRadius, mEyeAndMouthPaint);canvas.drawCircle(mCenterX + eyeOffsetX, mCenterY - eyeOffsetY, eyeRadius, mEyeAndMouthPaint);// draw mouthfloat mouthInset = mRadius /3f;mArcBounds.set(mouthInset, mouthInset, mRadius * 2 - mouthInset, mRadius * 2 - mouthInset);canvas.drawArc(mArcBounds, 45f, 90f, false, mEyeAndMouthPaint);
}

6.添加你的View

<FrameLayoutxmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"><com.example.app.SmileyViewandroid:layout_width="match_parent"android:layout_height="match_parent" />
</FrameLayout>

到此就结束了,自定义View没你想的那么难

转载自:Android开发中文站 » Android-6步教你自定义View

转载于:https://www.cnblogs.com/yuezhusust/p/6549318.html

Android-6步教你自定义View相关推荐

  1. Carson带你学Android:源码解析自定义View Draw过程

    前言 自定义View是Android开发者必须了解的基础 网上有大量关于自定义View原理的文章,但存在一些问题:内容不全.思路不清晰.无源码分析.简单问题复杂化 等 今天,我将全面总结自定义View ...

  2. android绘制心形_Android自定义View系列(一)——打造一个爱心进度条

    写作原因:Android进阶过程中有一个绕不开的话题--自定义View.这一块是安卓程序员更好地实现功能自主化必须迈出的一步.下面这个系列博主将通过实现几个例子来认识安卓自定义View的方法.从自定义 ...

  3. Android 雪花飘落动画效果 自定义View

    在码农的世界里,优美的应用体验,来源于程序员对细节的处理以及自我要求的境界,年轻人也是忙忙碌碌的码农中一员,每天.每周,都会留下一些脚印,就是这些创作的内容,有一种执着,就是不知为什么,如果你迷茫,不 ...

  4. Android中实现Bitmap在自定义View中的放大与拖动

    一基本实现思路: 基于View类实现自定义View –MyImageView类.在使用View的Activity类中完成OnTouchListener接口,实现对MotionEvent事件的监听与处理 ...

  5. Android软件开发之盘点自定义View界面大合集(二)

    Android软件开发之盘点自定义View界面大合集(二) - 雨松MOMO的程序世界 - 51CTO技术博客 雨松MOMO带大家盘点Android 中的自定义View界面的绘制 今天我用自己写的一个 ...

  6. android 仿360浮动,Android仿360悬浮小球自定义view实现示例

    Android仿360悬浮小球自定义view实现示例 效果图如下: 实现当前这种类似的效果 和360小球 悬浮桌面差不错类似.这种效果是如何实现的呢.废话不多说 ,直接上代码. 1.新建工程,添加悬浮 ...

  7. 一步一步教你自定义博客园(cnblog)界面

    一步一步教你自定义博客园(cnblog)界面 一.总结 二.一步一步教你自定义博客园(cnblog)界面 写在开头 我之前在博客园没怎么发东西,就是觉得博客园的Markdown不支持实时预览,加上ma ...

  8. Android仿IOS滑动关机-自定义view系列(6)

    Android仿IOS滑动关机-自定义view系列 功能简介 GIf演示 主要实现步骤-具体内容看github项目里的代码 Android技术生活交流 更多其他页面-自定义View-实用功能合集:点击 ...

  9. android canvas绘制圆角_Android自定义View撸一个渐变的温度指示器(TmepView)

    秦子帅明确目标,每天进步一点点..... 作者 |  andy 地址 |  blog.csdn.net/Andy_l1/article/details/82910061 1.概述 自定义View对需要 ...

最新文章

  1. jQuery validate 表单验证,涵盖各种类型数据
  2. Object类和String类
  3. 石油化工设备维护检修规程_旋回破碎机横梁臂架、衬板、内外铜套检修步骤及设备检修维护要点...
  4. java告警系统设计_告警系统的设计
  5. jquery获取元素内容-text()和val()
  6. 安卓案例:基于HttpClient下载文本与图片
  7. CVSNT Manual
  8. Perl语言如何学习总结
  9. SQL SERVER 2019安装 SQL Prompt 10.02版本
  10. 计算机360u盘删除,怎么关闭360U盘小助手
  11. android字节流保存,android数据存储之文件存储方法
  12. linux终端ANSI转义字符
  13. 这款手绘风格的在线制图软件超棒
  14. 媒体查询、移动端、网页响应式布局
  15. 物联网、大数据、云计算、人工智能之间的关系
  16. 刹那芳华,犹如指尖流砂
  17. 《C++ Primer Plus》学习笔记-string类和标准模板库
  18. 金融事业部QA培训体系
  19. 常用的javascript实例
  20. Java Maven项目对接金蝶SDK

热门文章

  1. Linux shell 编程入门 - 使用ubuntu-14.10
  2. matlab练习程序(最小二乘多项式拟合)
  3. Windows上安装scapy
  4. videoJS如何用
  5. 【转载】jQuery插件开发精品教程,让你的jQuery提升一个台阶
  6. java 20 -3 递归之删除特定目录下的特定文件
  7. JS拼凑方法之join
  8. android 中 系统日期时间的获取
  9. 在word中的公式以代码形式体现在web上的方法
  10. 基于MDA的移动应用开发建模及实现