自定义 view

为什么需要自定义 View 呢?

比如我们想实现一些自带控件无法实现的效果,如饼图、直方图。

了解自定义绘制。

一个 View 的绘制,是在View 的绘制方法里实现的,绘制方法写了什么内容,view 就怎么样绘制。而自定义绘制,就是需要重写 view 的绘制方法。

绘制方法有好几个,其中最常用的是 onDraw(),它负责 view 主体的绘制,例如 TextView 的文字、 ImageView 的图像。

而其他的绘制方法可以控制视图的遮盖关系。

具体执行绘制操作的,是 onDraw 里的 Canvas 参数。Canvas 就是 Android 里的绘制工具。

了解 Canvas 的方法

Canvas.绘制类方法

  • drawCicle();
  • drawRect();
  • drawPath(); 这个方法是通过描述路径的方式来绘制图形的,绘制组合图形
  • drawBitmap();
  • drawText();
  • drawPoint();
  • ...

canvas.drawCircle(300, 300, 200, paint);

坐标值: 在 Android 里,每个 View 都有一个自己的坐标系,彼此之间是不影响的。这个坐标系的原点是 View 左上角的那个点;水平方向是 x 轴,右正左负;竖直方向是 y 轴,下正上负

Andriod里的 Paint 类,负责绘制时的颜色和风格信息。所谓风格,就是比如画一个圆,是空心还是实心,线条粗细、有无阴影等。

Canvas.辅助类方法

  • ClipXXX();范围裁切
  • Matrix;几何变换

了解 Paint 的方法

  • Paint.setStyle(Style style) 设置绘制模式
  1. FILL 是填充模式,STROKE 是画线模式(即勾边模式),FILL_AND_STROKE 是两种模式一并使用:既画线又填充。它的默认值是 FILL,填充模式。paint.setStyle(Paint.Style.STROKE); // Style 修改为画线模式
  • Paint.setColor(int color) 设置颜色
  • Paint.setStrokeWidth(float width) 设置线条宽度
  • Paint.setTextSize(float textSize) 设置文字大小
  • Paint.setAntiAlias(boolean aa) 设置抗锯齿开关

了解drawPath

Path 有两类方法:

  1. 直接描述路径

    1.1 addXXX():添加子图形

java 复制代码
path.addCircle(300, 300, 200, Path.Direction.CW);
...
canvas.drawPath(path, paint);

1.2 xxxTo() :画线,直线或曲线

lineTo(float x, float y) / rLineTo(float x, float y) 画直线

moveTo(float x, float y) / rMoveTo(float x, float y) 移动到目标位置

moveTo(x, y) 虽然不添加图形,但它会设置图形的起点,所以它是非常重要的一个辅助方法。

arcTo(RectF oval, float startAngle, float sweepAngle, boolean forceMoveTo) / arcTo(float left, float top, float right, float bottom, float startAngle, float sweepAngle, boolean forceMoveTo) / arcTo(RectF oval, float startAngle, float sweepAngle) 画弧形

close() 封闭当前子图形

它的作用是把当前的子图形封闭,即由当前位置向当前子图形的起点绘制一条直线。

  1. 辅助设置或计算

Path.setFillType(Path.FillType ft) 设置填充方式

相关推荐
沐怡旸1 小时前
【底层机制】【Android】深入理解UI体系与绘制机制
android·面试
啊森要自信1 小时前
【GUI自动化测试】YAML 配置文件应用:从语法解析到 Python 读写
android·python·缓存·pytest·pip·dash
下位子2 小时前
『AI 编程』用 Codex 开发识字小帮手应用
android·openai·ai编程
Zender Han3 小时前
Flutter 实现人脸检测 — 使用 google_mlkit_face_detection
android·flutter·ios
君逸臣劳3 小时前
玩Android Flutter版本,通过项目了解Flutter项目快速搭建开发
android·flutter
叫我龙翔3 小时前
【MySQL】从零开始了解数据库开发 --- 基本查询
android·mysql·数据库开发
2501_916008893 小时前
iOS 26 性能分析深度指南 包含帧率、渲染、资源瓶颈与 KeyMob 协助策略
android·macos·ios·小程序·uni-app·cocoa·iphone
撩得Android一次心动5 小时前
Android adb 基础使用指南
android·adb
为java加瓦5 小时前
PHP MQTT 订阅服务:实时消息接收与数据库存储解决方案
android
怿星科技5 小时前
Android MVVM架构解析:现代开发的首选模式
android·架构