鸿蒙画布组件使用介绍

news2025/1/24 11:47:59

一、前言

DevEco Studio版本:4.0.0.600

前些天写了一篇 鸿蒙自定义控件实现罗盘数字时钟效果 的文章,有同学私信说能不能介绍鸿蒙中的画布组件,下面文章介绍下鸿蒙中的Canvas画布、CanvasRenderingContext2D绘制组件,实现绘制文本、矩形、线条、圆形、椭圆、三角形、扇形、图片等。

Canvas:提供画布组件,用于自定义绘制图形。

CanvasRenderingContext2D:使用RenderingContext在Canvas组件上进行绘制,绘制对象可以是矩形、文本、图片等,相当于画笔

RenderingContextSettings:用来配置CanvasRenderingContext2D对象的参数,包括是否开启抗锯齿

参考链接:OpenHarmony CanvasRenderingContext2D

二、实现效果

三、具体实现逻辑

1、初始化

private settings: RenderingContextSettings = new RenderingContextSettings(true)
private context: CanvasRenderingContext2D = new CanvasRenderingContext2D(this.settings)
private img: ImageBitmap = new ImageBitmap("images/startIcon.png")

build() {
   Stack({ alignContent: Alignment.Center }) {
      Canvas(this.context)
         .padding({ top: 76 })
         .width('100%')
         .height('100%')
         .onReady(() => {
            this.drawCanvas()
         })
   }
   .width('100%')
   .height('100%')
}


//画布逻辑
private drawCanvas(): void {
   this.context.fillStyle = '#0080DC' //画笔填充颜色
   this.context.strokeStyle = '#0080DC' //画笔线条颜色
   this.context.font = '22px' //字体大小
}

2、画文字

//画文字
this.context.fillText("Hello World!", 10, 10)

3、画矩形

//画矩形
this.context.strokeRect(10, 30, 100, 100)

4、画线条

//画线
this.context.beginPath()
this.context.moveTo(10, 150)
this.context.lineTo(180, 200)
this.context.stroke()

5、画圆形

//画圆形
this.context.beginPath()
this.context.arc(60, 250, 50, 0, 2 * Math.PI)
this.context.stroke()

6、画椭圆形

//画椭圆形
this.context.beginPath()
this.context.ellipse(100, 360, 50, 100, Math.PI * 0.5, 0, Math.PI * 2)
this.context.stroke()

7、画三角形

先画两条线,然后通过closePath()方法实现闭环,依次达到画三角形效果

//画三角形
this.context.beginPath()
this.context.moveTo(10, 500)
this.context.lineTo(60, 420)
this.context.lineTo(120, 500)
this.context.closePath()
this.context.stroke()

 

8、画扇形

先画弧线,在画两条基于弧线起点和终点的线,依次来达到画扇形的效果

//画扇形
this.context.beginPath()
this.context.arc(110, 620, 100, Math.PI, 1.75 * Math.PI)
this.context.moveTo(10, 620)
this.context.lineTo(110, 620)
this.context.lineTo(180.71, 549.29)
this.context.stroke()

9、画图片

//画图片
this.context.drawImage(this.img, 0, 0, 144, 144, 150, 0, 144, 144)

10、画二阶贝赛尔曲线的路径

原理演示动画:

效果:

代码实现:

import display from '@ohos.display'

@Entry
@Component
struct Index {
   private settings: RenderingContextSettings = new RenderingContextSettings(true)
   private context: CanvasRenderingContext2D = new CanvasRenderingContext2D(this.settings)
   private mDisplayWidth: number
   private mDisplayHeight: number

   aboutToAppear() {
      this.getSize()
   }

   // 获取设备宽高计算表盘大小
   async getSize() {
      let mDisplay = await display.getDefaultDisplay()
      this.mDisplayWidth = mDisplay.width
      this.mDisplayHeight = mDisplay.height
   }

   build() {
      Stack({ alignContent: Alignment.Center }) {
         Canvas(this.context)
            .padding({ top: 76 })
            .width('100%')
            .height('100%')
            .onReady(() => {
               this.drawCanvas()
            })
            .onTouch((event) => this.touchEvent(event))
      }
      .width('100%')
      .height('100%')
   }

   private drawCanvas(): void {
      this.context.clearRect(0, 0, this.mDisplayWidth, this.mDisplayHeight)
      this.context.strokeStyle = '#0080DC' //画笔线条颜色
      this.context.lineWidth = 3
      this.context.font = '22px' //字体大小
      //画第一个圆
      this.context.beginPath()
      this.context.arc(20, 200, 5, 0, 2 * Math.PI)
      this.context.stroke()
      //画第二个圆
      this.context.beginPath()
      this.context.arc(305, 200, 5, 0, 2 * Math.PI)
      this.context.stroke()
      //画贝塞尔曲线
      this.context.beginPath()
      this.context.moveTo(20, 195)
      this.context.quadraticCurveTo(this.eventX, this.eventY, 300, 200)
      this.context.stroke()
   }

   @State eventX: number = 0
   @State eventY: number = 500

   touchEvent(event: TouchEvent) {
      switch (event.type) {
         case TouchType.Down: // 手指按下
         case TouchType.Move: // 手指移动
            this.eventX = event.touches[0].x
            this.eventY = event.touches[0].y
            this.drawCanvas()
            break
      }
   }
}

11、画三阶贝赛尔曲线的路径

原理演示动画:

效果:

代码实现:

import display from '@ohos.display'

@Entry
@Component
struct Index {
   private settings: RenderingContextSettings = new RenderingContextSettings(true)
   private context: CanvasRenderingContext2D = new CanvasRenderingContext2D(this.settings)
   private mDisplayWidth: number
   private mDisplayHeight: number
   @State isFirst: boolean = true

   aboutToAppear() {
      this.getSize()
   }

   // 获取设备宽高计算表盘大小
   async getSize() {
      let mDisplay = await display.getDefaultDisplay()
      this.mDisplayWidth = mDisplay.width
      this.mDisplayHeight = mDisplay.height
   }

   build() {
      Stack({ alignContent: Alignment.Center }) {
         Canvas(this.context)
            .padding({ top: 76 })
            .width('100%')
            .height('100%')
            .onReady(() => {
               this.drawCanvas()
            })
            .onTouch((event) => this.touchEvent(event))

         Button(`点击切换,当前${this.isFirst ? '第一点' : '第二点'}`)
            .onClick(() => {
               this.isFirst = !this.isFirst
            })
      }
      .alignContent(Alignment.TopStart)
      .width('100%')
      .height('100%')
   }

   private drawCanvas(): void {
      this.context.clearRect(0, 0, this.mDisplayWidth, this.mDisplayHeight)
      this.context.strokeStyle = '#0080DC' //画笔线条颜色
      this.context.lineWidth = 3
      this.context.font = '22px' //字体大小
      //画第一个圆
      this.context.beginPath()
      this.context.arc(20, 200, 5, 0, 2 * Math.PI)
      this.context.stroke()
      //画第二个圆
      this.context.beginPath()
      this.context.arc(405, 200, 5, 0, 2 * Math.PI)
      this.context.stroke()
      //画贝塞尔曲线
      this.context.beginPath()
      this.context.moveTo(20, 195)
      this.context.bezierCurveTo(this.eventFirstX, this.eventFirstX, this.eventSecondX, this.eventSecondY, 400, 200)
      this.context.stroke()
      this.context.stroke()
   }

   @State eventFirstX: number = 120
   @State eventFirstY: number = 50
   @State eventSecondX: number = 200
   @State eventSecondY: number = 500

   touchEvent(event: TouchEvent) {
      switch (event.type) {
         case TouchType.Down: // 手指按下
         case TouchType.Move: // 手指移动
            if (this.isFirst) {
               this.eventFirstX = event.touches[0].x
               this.eventFirstY = event.touches[0].y
            } else {
               this.eventSecondX = event.touches[0].x
               this.eventSecondY = event.touches[0].y
            }
            this.drawCanvas()
            break
      }
   }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1600792.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

权限管理Ranger详解

文章目录 一、Ranger概述与安装1、Ranger概述1.1 Ranger介绍1.2 Ranger的目标1.3 Ranger支持的框架1.4 Ranger的架构1.5 Ranger的工作原理 2、Ranger安装2.1 创建系统用户和Kerberos主体2.2 数据库环境准备2.3 安装RangerAdmin2.4 启动RangerAdmin 二、Ranger简单使用1、安装 R…

Docker Container (容器) 常见命令

Docker 容器的生命周期 什么是容器? 通俗地讲,容器是镜像的运行实体。镜像是静态的只读文件,而容器带有运行时需要的可写文件层,并且容器中的进程属于运行状态。即容器运行着真正的应用进程。容 器有初建、运行、停止、暂停和删除…

Unity类银河恶魔城学习记录12-18,19 p140 Options UI-p141 Finalising ToolTip源代码

Alex教程每一P的教程原代码加上我自己的理解初步理解写的注释,可供学习Alex教程的人参考 此代码仅为较上一P有所改变的代码 【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili UI_ToolTip.cs using TMPro; using UnityEngine;public class UI_ToolTip :…

Git回滚操作,工作区和暂存区恢复修改删除的文件

在利用git协作过程中,经常需要进行代码的撤销操作,这个行为可能发生在工作区,暂存区或者仓库区(或版本库)。 我们先讨论在工作区与暂存区发生的撤销行为,这里会有两个命令提供帮助,git restore…

【管理咨询宝藏72】MBB大型城投集团能源板块行业分析报告

本报告首发于公号“管理咨询宝藏”,如需阅读完整版报告内容,请查阅公号“管理咨询宝藏”。 【管理咨询宝藏72】MBB大型城投集团能源板块行业分析报告 【格式】PDF版本 【关键词】战略规划、商业分析、管理咨询、MBB顶级咨询公司 【强烈推荐】 这是一套…

【Phytium】飞腾D2000 UEFI/EDK2 适配 RTC(IIC SD3077)

文章目录 0. env1. 软件2. 硬件 10. 需求1. 硬件2. 软件 20. DatasheetCPURTC 30. 调试步骤1. 硬件环境搭建2. UEFI 开发环境搭建3. 修改步骤1. UEFI 中使能RTC驱动、配置RTC信息等1.1 使能RTC驱动1.2 修改RTC对应的IIC配置信息1.3 解决驱动冲突1.4 验证波形 2. 修改对应RTC驱动…

2.2 @SpringBootApplication

2.2 SpringBootApplication 在前文的介绍中,读者已经了解到SpringBootApplication注解是加在项目的启动类上的。 SpringBootApplication实际上是一个组合注解,定义如下: SpringBootConfiguration EnableAutoConfiguration ComponentScan(exc…

Qt 实战(2)搭建开发环境 | 2.1、Windows下安装QT

一、Windows下安装QT 1、QT官网 QT官网:https://download.qt.io/,打开官网地址,如下: 目录结构介绍 目录说明snapshots预览版,最新的开发测试中的 Qt 库和开发工具onlineQt 在线安装源official_releases正式发布版&am…

STM32 F103 C8T6开发笔记14:与HLK-LD303-24G测距雷达通信

今日尝试配通STM32 F103 ZET6与HLK-LD303-24G测距雷达的串口通信解码 文章提供测试代码...... 目录 HLK-LD303-24G测距雷达外观: 线路连接准备: 定时器与串口配置准备: 定时器2的初始化: 串口1、2初始化: 串口1、2自定…

Vue加载glb / gltf模型(如何在vue中使用Three.js,vue使用threejs加载glb模型)

简介:Three.js 是一个用于在 Web 上创建和显示 3D 图形的 JavaScript 库。它提供了丰富的功能和灵活的 API,使开发者可以轻松地在网页中创建各种 3D 场景、模型和动画效果。可以用来展示产品模型、建立交互式场景、游戏开发、数据可视化、教育和培训等等…

互联网大厂ssp面经,数据结构:part1

1. 数组和链表的区别是什么? a. 数组是一种线性数据结构,存储在连续的内存块中,元素可以通过索引直接访问。 b. 链表是由节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。 2. 数组和链表的的优缺点是什么&#xff…

原始部落版本潮玩宇宙小程序定制大逃杀游戏APP开发H5游戏

原始部落版本潮玩宇宙小程序定制大逃杀游戏APP开发H5游戏 潮玩宇宙小程序定制大逃杀游戏APP开发H5游戏 潮玩宇宙大逃杀小游戏模块成品源码,可嵌入任何平台系统,增加用户粘性,消除泡沫,短视频直播引流。 玩家选择一间房间躲避杀手…

VBA脚本: excel隐藏和展开指定行 【图文】

打开开发工具功能 【文件】-》【选项】-》【自定义功能区】-》勾选【开发工具】-》【确定】 代开VBA编辑器 【开发工具】-》【Visual Basic】 插入模块 编写代码 所有sheet 关闭 Sub HideRowsInAllSheets()Dim ws As WorksheetDim i As Integer 循环遍历所有工作表For E…

STM32学习和实践笔记(13):数码管显示实验

共阳就是共正极,也就是正极全部接在一起。 共阴就是共负极,也就是负极全部接在一起。 我目前使用这款PZ6806L,使用了一个共阳数码管。 共阴与共阳在码表上其实就是正好取反就可以了,所以可以共用一个码表。 数码管显示程序主要分…

bp神经网络拟合函数未知参数【源码+视频教程】

专栏导读 作者简介:工学博士,高级工程师,专注于工业软件算法研究本文已收录于专栏:《复杂函数拟合案例分享》本专栏旨在提供 1.以案例的形式讲解各类复杂函数拟合的程序实现方法,并提供所有案例完整源码;2.…

【Java】通过poi给word首页添加水印图片

背景: poi并没有提供直接插入水印图片的方法,目前需要再word的首页插入一张水印图片,于是就需要通过另一种方式,插入透明图片(png格式)并将图片设置为“浮于文字上方”的方式实现该需求。 所需jar&#xf…

AI智能体技术突破:引领科技新浪潮

AI智能体技术突破:引领科技新浪潮 基于大模型的 AI Agent 工作流基于大模型的 AI Agent 工作流效果AI Agent 的四种设计模式Reflection 反思设计模式Tool use 工具使用设计模式Planning 规划设计模式Multiagent collaboration 多智能体协作设计模式 吴恩达在红杉美国…

吃透2000-2024年600道真题和解析,科学高效通过2025年AMC8竞赛

为帮助孩子科学、有效备考AMC8竞赛,我整理了2000-2004年的全部AMC8真题(完整版共600道,且修正了官方发布的原试卷中的少量bug),并且独家制作成多种在线练习,利用碎片化时间,8个多月的时间足以通…

【C++题解】1317. 正多边形每个内角的度数?

问题:1317. 正多边形每个内角的度数? 类型:基本运算、小数运算 题目描述: 根据多边形内角和定理,正多边形内角和等于:( n-2 ) 180∘ ( n 大于等于 3 且 n 为整数&#…

Backend - Django Swagger

目录 一、安装依赖 二、配置环境 三、路由(urls) 四、swagger UI 界面 (一)UI 界面 (二)单引号问题:Expecting property name enclosed in double quotes 1. 原因 2. 解决 五、自定义s…