| |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| -> 移动开发 -> android 自定义view实现手签 -> 正文阅读 |
|
|
[移动开发]android 自定义view实现手签 |
public class SignView extends View {
int painColor = Color.BLACK; //画笔颜色
float paintSize = 8;//画笔宽度
Path path;//路径
Paint paint;//画笔
float start_x, start_y, click_x, click_y;//坐标点
public SignView(Context context) {//代码new用的
this(context, null);
}
public SignView(Context context, @Nullable AttributeSet attrs) {
this(context, attrs, 0);
}
public SignView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
initPaint(); //实例化paint
}
private void initPaint() {
path = new Path();
paint = new Paint();
paint.setStrokeWidth(paintSize);
paint.setColor(painColor);
paint.setAntiAlias(true);//抗锯齿
paint.setStyle(Paint.Style.STROKE);//样式
}
@Override
protected void onDraw(Canvas canvas) {
canvas.drawPath(path, paint);//画路线
}
@Override
public boolean onTouchEvent(MotionEvent event) {
start_x = event.getX();//记录当前的坐标
start_y = event.getY();
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
return downEvent();
case MotionEvent.ACTION_MOVE:
moveEvent();
default:
break;
}
return super.onTouchEvent(event);
}
private void moveEvent() {
click_x = start_x;
click_y = start_y;
path.quadTo(click_x, click_y, (start_x + click_x) / 2, (start_y + click_y) / 2);
invalidate();
}
private boolean downEvent() {
click_x = start_x;//保存起点坐标
click_y = start_y;
path.moveTo(start_x, start_y);//移动画笔
return true;
}
public void clear(){
if (path!=null){
path.reset();
}
invalidate();
}
}
|
|
|
| 移动开发 最新文章 |
| Vue3装载axios和element-ui |
| android adb cmd |
| 【xcode】Xcode常用快捷键与技巧 |
| Android开发中的线程池使用 |
| Java 和 Android 的 Base64 |
| Android 测试文字编码格式 |
| 微信小程序支付 |
| 安卓权限记录 |
| 知乎之自动养号 |
| 【Android Jetpack】DataStore |
|
|
| 上一篇文章 下一篇文章 查看所有文章 |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| 360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年12日历 | -2025/12/3 9:54:24- |
|
| 网站联系: qq:121756557 email:121756557@qq.com IT数码 |