Android 使用Path实现涂鸦功能

发布时间 - 2026-01-10 21:53:07    点击率:

今天实现一个涂鸦效果,会分几步实现,这里有一个重要的知识点就是图层,要理解这个,不然你看这篇博客,很迷茫,迷茫的苍茫的天涯是我的爱,先从简单的需求做起,绘制一条线,代码如下:

package com.tuya;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.Path;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
/**
 * Created by admin on 2016/12/16.
 */
public class GraffitiView extends View{
  private Paint paint;
  private Path path;
  private float downX,downY;
  private float tempX,tempY;
  public GraffitiView(Context context) {
    this(context,null);
  }
  public GraffitiView(Context context, AttributeSet attrs) {
    this(context, attrs,0);
  }
  public GraffitiView(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
    init();
  }
  private void init() {
    paint = new Paint();
    paint.setAntiAlias(true);
    paint.setStrokeWidth(10);
    paint.setStyle(Paint.Style.STROKE);
    path = new Path();
  }
  @Override
  protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
    if(path!=null){
      canvas.drawPath(path,paint);
    }
  }
  @Override
  public boolean onTouchEvent(MotionEvent event) {
    switch (event.getAction()){
      case MotionEvent.ACTION_DOWN:
        downX = event.getX();
        downY = event.getY();
        path.moveTo(downX,downY);
        invalidate();
        tempX = downX;
        tempY = downY;
        break;
      case MotionEvent.ACTION_MOVE:
        float moveX = event.getX();
        float moveY = event.getY();
        path.quadTo(tempX,tempY,moveX,moveY);
        invalidate();
        tempX = moveX;
        tempY = moveY;
        break;
    }
    return true;
  }
}

效果:

如果你不使用path的quadTo()用lineTo()方法也行,但是没有使用queadTo()绘制出来的路径光滑,这5条路径是怎么绘制到屏幕上去的呢?上面说了图层的概念,如果不懂,可以去看下我之前写的关于canvas博客,也可以去网上看其他的博客,
我们知道每次canvas.draw...()其实都会产生新的图层,只是图层是透明的,最后隐射到画布(canvas)上,画布分析:

以上所述是小编给大家介绍的Android 使用Path实现涂鸦功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# android  # path  # 涂鸦效果  # Android实现签名涂鸦手写板  # android中实现在ImageView上随意画线涂鸦的方法  # android 实现在照片上绘制涂鸦的方法  # Android编程实现的手写板和涂鸦功能  # Android实现Path平滑的涂鸦效果实例  # Android 开发实例简单涂鸦板  # Android编程实现在Bitmap上涂鸦效果  # AndroidStudio实现能在图片上涂鸦程序  # 图层  # 小编  # 博客  # 在此  # 说了  # 是怎么  # 不懂  # 你看  # 去看  # 给大家  # 几步  # 这篇  # 我的爱  # 也行  # 所述  # 给我留言  # 感谢大家  # 有一个  # 一条线  # 如果你不 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧  Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  详解jQuery停止动画——stop()方法的使用  Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区  大连 网站制作,大连天途有线官网?  深圳网站制作平台,深圳市做网站好的公司有哪些?  EditPlus中的正则表达式实战(5)  中山网站推广排名,中山信息港登录入口?  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?  Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】  详解Android图表 MPAndroidChart折线图  Laravel中的withCount方法怎么高效统计关联模型数量  php485函数参数是什么意思_php485各参数详细说明【介绍】  nodejs redis 发布订阅机制封装实现方法及实例代码  网易LOFTER官网链接 老福特网页版登录地址  油猴 教程,油猴搜脚本为什么会网页无法显示?  JavaScript如何实现倒计时_时间函数如何精确控制  Swift中swift中的switch 语句  如何快速打造个性化非模板自助建站?  Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能  英语简历制作免费网站推荐,如何将简历翻译成英文?  Python结构化数据采集_字段抽取解析【教程】  如何在IIS7中新建站点?详细步骤解析  韩国服务器如何优化跨境访问实现高效连接?  Laravel怎么使用Intervention Image库处理图片上传和缩放  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  简单实现Android文件上传  使用spring连接及操作mongodb3.0实例  如何用AWS免费套餐快速搭建高效网站?  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  如何正确选择百度移动适配建站域名?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  深圳网站制作的公司有哪些,dido官方网站?  Linux系统命令中screen命令详解  Android 常见的图片加载框架详细介绍  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势  Laravel怎么上传文件_Laravel图片上传及存储配置  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  三星网站视频制作教程下载,三星w23网页如何全屏?  浅谈javascript alert和confirm的美化