网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

Android中怎么实现基本画笔功能-创新互联

本篇内容主要讲解“Android中怎么实现基本画笔功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android中怎么实现基本画笔功能”吧!

站在用户的角度思考问题,与客户深入沟通,找到文山州网站设计与文山州网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站建设、成都网站设计、企业官网、英文网站、手机端网站、网站推广、申请域名网站空间、企业邮箱。业务覆盖文山州地区。

一、简介


带大家实现一个最简单的画板,前提是需要对自定义View有一定的了解。


用的是kotlin语言

Android中怎么实现基本画笔功能

二、实现


分析如何实现: 定义了画笔和Path,然后在触摸屏幕的时候,手指一边移动一边进行path的滑动,绘制。这就完成了一个最简单的画笔功能。

下面几十行代码完成这个

 class TPView(context: Context,attr:AttributeSet ) : View(context,attr) {


  private var preX: Float = 0.0f //上一次的触摸点x坐标
  private var preY: Float = 0.0f //上一次触摸点y坐标

  var mPath = Path()  //path路径

  //画笔
  private var mPaint = Paint(Paint.ANTI_ALIAS_FLAG or Paint.DITHER_FLAG)

  init {
    //画笔为实心
    mPaint.style = Paint.Style.STROKE
    //颜色
    mPaint.color = Color.RED
    //笔触为圆形
    mPaint.strokeCap = Paint.Cap.ROUND
    //画笔大小
    mPaint.strokeWidth = 10f
    //View的背景颜色
    setBackgroundColor(Color.WHITE)
  }

  override fun onDraw(canvas: Canvas) {
    super.onDraw(canvas)
    //画线
    canvas.drawPath(mPath,mPaint)
  }

  override fun onTouchEvent(event: MotionEvent): Boolean {

    when(event.action){
      MotionEvent.ACTION_DOWN -> { //手指按下的时候
        //将起始点移动到当前坐标
        mPath.moveTo(event.x,event.y)
        //记录上次触摸的坐标,注意ACTION_DOWN方法只会执行一次
        preX = event.x
        preY = event.y
      }
      MotionEvent.ACTION_MOVE -> { //手指移动的时候

        //绘制圆滑曲线,即贝塞尔曲线,贝塞尔曲线这个知识自行了解
        mPath.quadTo(preX,preY,event.x,event.y)

        preX = event.x
        preY = event.y
      }
    }

    //重新绘制,会调用onDraw方法
    invalidate()
    return true
  }

}

到此,相信大家对“Android中怎么实现基本画笔功能”有了更深的了解,不妨来实际操作一番吧!这里是创新互联建站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


本文题目:Android中怎么实现基本画笔功能-创新互联
路径分享:http://bjjierui.cn/article/ghsjg.html

其他资讯