鸿蒙自定义组件之鸿蒙画板

 更新时间:2020年09月22日 14:44:14   作者:NoPointException  
这篇文章主要为大家详细介绍了鸿蒙自定义组件之鸿蒙画板,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

初识鸿蒙OS 2.0

华为的鸿蒙OS 2.0是目前唯一个有希望和安卓、IOS对抗的全新生态系统。9月10日,在东莞正式发布。华为喊出了“HarmonyOS 2.0 连接无限可能”的口号,将是未来十年很有竞争力的优秀操作系统。

自定义Component

这里我编写一个简易的画板。

1.新建一个类DrawComponment 继承自Componment;
2.实现Component.TouchEventListener,用于对touch事件生成相应的path;
3.实现Component.DrawTask,用于把path画到屏幕上;

代码

DrawComponment

package com.quqx.draw;

import ohos.agp.components.Component;
import ohos.agp.render.Canvas;
import ohos.agp.render.Paint;
import ohos.agp.render.Path;
import ohos.agp.utils.Color;
import ohos.agp.utils.Point;
import ohos.app.Context;
import ohos.hiviewdfx.HiLog;
import ohos.hiviewdfx.HiLogLabel;
import ohos.media.image.PixelMap;
import ohos.multimodalinput.event.MmiPoint;
import ohos.multimodalinput.event.TouchEvent;

public class DrawComponment extends Component implements Component.DrawTask, Component.TouchEventListener {
  private static final String TAG = "DrawComponment";
  PixelMap mPixelMap;
  Canvas mCanvas;
  Path mPath = new Path();
  Paint mPaint;
  Point mPrePoint = new Point();
  Point mPreCtrlPoint = new Point();

  public DrawComponment(Context context) {
    super(context);
    //初始化paint
    mPaint = new Paint();
    mPaint.setColor(Color.WHITE);
    mPaint.setStrokeWidth(5f);
    mPaint.setStyle(Paint.Style.STROKE_STYLE);
    //添加绘制任务
    addDrawTask(this::onDraw);
    //设置TouchEvent监听
    setTouchEventListener(this::onTouchEvent);
  }

  @Override
  public void onDraw(Component component, Canvas canvas) {
    canvas.drawPath(mPath, mPaint);
  }


  @Override
  public boolean onTouchEvent(Component component, TouchEvent touchEvent) {
    switch (touchEvent.getAction()) {
      case TouchEvent.PRIMARY_POINT_DOWN: {
        //鸿蒙Log工具
        HiLog.debug(new HiLogLabel(0, 0, TAG), "TouchEvent.PRIMARY_POINT_DOWN");
        //获取点信息
        MmiPoint point = touchEvent.getPointerPosition(touchEvent.getIndex());
        mPath.reset();
        mPath.moveTo(point.getX(), point.getY());
        mPrePoint.position[0] = point.getX();
        mPrePoint.position[1] = point.getY();
        mPreCtrlPoint.position[0] = point.getX();
        mPreCtrlPoint.position[1] = point.getY();
        //PRIMARY_POINT_DOWN 一定要返回true
        return true;
      }
      case TouchEvent.PRIMARY_POINT_UP:

        break;
      case TouchEvent.POINT_MOVE: {
        HiLog.debug(new HiLogLabel(0, 0, TAG), "TouchEvent.POINT_MOVE");
        MmiPoint point = touchEvent.getPointerPosition(touchEvent.getIndex());
        Point currCtrlPoint = new Point((point.getX() + mPrePoint.position[0]) / 2,
            (point.getY() + mPrePoint.position[1]) / 2);
        //绘制三阶贝塞尔曲线
        mPath.cubicTo(mPrePoint, mPreCtrlPoint, currCtrlPoint);
        mPreCtrlPoint.position[0] = currCtrlPoint.position[0];
        mPreCtrlPoint.position[1] = currCtrlPoint.position[1];
        mPrePoint.position[0] = point.getX();
        mPrePoint.position[1] = point.getY();
        //更新显示
        invalidate();
        break;
      }

    }
    return false;
  }
}

MainAbilitySlice

package com.quqx.draw.slice;

import com.quqx.draw.DrawComponment;
import ohos.aafwk.ability.AbilitySlice;
import ohos.aafwk.content.Intent;

import ohos.agp.components.DirectionalLayout;
import ohos.agp.components.DirectionalLayout.LayoutConfig;
import ohos.agp.components.Text;
import ohos.agp.colors.RgbColor;
import ohos.agp.components.element.ShapeElement;
import ohos.agp.utils.Color;
import ohos.agp.utils.TextAlignment;

public class MainAbilitySlice extends AbilitySlice {

  private DirectionalLayout myLayout = new DirectionalLayout(this);

  @Override
  public void onStart(Intent intent) {
    super.onStart(intent);
    LayoutConfig config = new LayoutConfig(LayoutConfig.MATCH_PARENT, LayoutConfig.MATCH_PARENT);
    myLayout.setLayoutConfig(config);

    DrawComponment drawComponment = new DrawComponment(this);
    drawComponment.setLayoutConfig(config);
    ShapeElement element = new ShapeElement();
    element.setRgbColor(new RgbColor(0, 0, 0));
    drawComponment.setBackground(element);
    myLayout.addComponent(drawComponment);

    super.setUIContent(myLayout);
  }

  @Override
  public void onActive() {
    super.onActive();
  }

  @Override
  public void onForeground(Intent intent) {
    super.onForeground(intent);
  }
}

效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 华为鸿蒙OS之HelloWorld的实现

    华为鸿蒙OS之HelloWorld的实现

    这篇文章主要介绍了华为鸿蒙OS之HelloWorld的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 鸿蒙HarmonyO开发实战-Web组件中的Cookie及数据存储

    鸿蒙HarmonyO开发实战-Web组件中的Cookie及数据存储

    Cookie是一种存储在用户计算机上的小文本文件,用于在用户访问网站时存储和提取信息,它由网站服务器发送到用户的浏览器,并存储在用户的计算机上,每当用户访问该网站时,浏览器将发送该Cookie回服务器,以用于识别用户和存储用户的首选项和其他信息
    2024-06-06
  • 浅析鸿蒙开发app支持JavaScript?上手HelloWorld,体验究竟香不香

    浅析鸿蒙开发app支持JavaScript?上手HelloWorld,体验究竟香不香

    这篇文章主要介绍了浅析鸿蒙开发app支持JavaScript?上手HelloWorld,体验究竟香不香,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 好人共享的一个万能Ghost系统制作教程附相关软件下载

    好人共享的一个万能Ghost系统制作教程附相关软件下载

    好人共享的一个万能Ghost系统制作教程附相关软件下载...
    2007-11-11
  • 系统定时启动服务2种实现方法

    系统定时启动服务2种实现方法

    系统定时启动服务:在规定的时间内运行指定的服务,下面与大家分享下2种实现方法,感兴趣的朋友可以参考下哈
    2013-06-06
  • Jetson tk2开发部署实现过程图解

    Jetson tk2开发部署实现过程图解

    这篇文章主要介绍了Jetson tk2开发部署实现过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • 鸿蒙OS运行第一个“hello world”

    鸿蒙OS运行第一个“hello world”

    这篇文章主要介绍了鸿蒙OS运行第一个“hello world”,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 鸿蒙HAIWEI DevEco Studio安装配置运行Hello World的实现

    鸿蒙HAIWEI DevEco Studio安装配置运行Hello World的实现

    这篇文章主要介绍了鸿蒙HAIWEI DevEco Studio安装配置运行Hello World,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • ip地址掩码和位数对应关系由浅入深理解(192.168.0.0/24)

    ip地址掩码和位数对应关系由浅入深理解(192.168.0.0/24)

    192.168.0.0/24这是IP地址的一个规范写法,前面是IP地址,后面跟一个斜杠以及一个数字,这条斜杠及后面的数字称为网络掩码(network mask)。斜杠后面的数字表示有意义的比特位的个数(从左到右)。ip地址后面的斜杠24表示掩码位是24位的,即用32位二进制表示的子网...
    2023-06-06
  • 鸿蒙自定义组件之鸿蒙画板

    鸿蒙自定义组件之鸿蒙画板

    这篇文章主要为大家详细介绍了鸿蒙自定义组件之鸿蒙画板,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09

最新评论