「Mac畅玩鸿蒙与硬件20」鸿蒙UI组件篇10 - Canvas 组件自定义绘图

简介: Canvas 组件在鸿蒙应用中用于绘制自定义图形,提供丰富的绘制功能和灵活的定制能力。通过 Canvas,可以创建矩形、圆形、路径、文本等基础图形,为鸿蒙应用增添个性化的视觉效果。本篇将介绍 Canvas 组件的基础操作,涵盖绘制矩形、圆形、路径和文本的实例。

Canvas 组件在鸿蒙应用中用于绘制自定义图形,提供丰富的绘制功能和灵活的定制能力。通过 Canvas,可以创建矩形、圆形、路径、文本等基础图形,为鸿蒙应用增添个性化的视觉效果。本篇将介绍 Canvas 组件的基础操作,涵盖绘制矩形、圆形、路径和文本的实例。


关键词
  • Canvas 组件
  • 绘图
  • 矩形绘制
  • 圆形绘制
  • 路径与文本

一、Canvas 组件概述

Canvas 组件是鸿蒙中用于自定义图形绘制的关键组件。通过 Canvas,开发者可以绘制多种图形元素,包括矩形、圆形、路径和文本,满足应用中各种个性化的设计需求。


二、基础图形绘制

2.1 绘制矩形

Canvas 提供了 fillRectstrokeRect 方法,可以绘制填充矩形和描边矩形。

@Entry
@Component
struct RectangleCanvasExample {
   
  build() {
   
    Column() {
   
      Canvas(this.context)
        .width('100%')
        .height(500)
        .onReady(() => {
   
          // 设置填充颜色为蓝色
          this.context.fillStyle = '#0000FF';
          // 绘制填充矩形
          this.context.fillRect(150, 150, 300, 200);

          // 设置描边颜色为黑色
          this.context.strokeStyle = '#000000';
          // 设置描边宽度为 5
          this.context.lineWidth = 5;
          // 绘制描边矩形
          this.context.strokeRect(150, 150, 300, 200);
        });
    }
  }

  private context: CanvasRenderingContext2D = new CanvasRenderingContext2D();
}

效果示例:在画布上绘制一个蓝色填充、黑色边框的矩形。

Screenshot_2024-11-01T225918.png


2.2 绘制圆形

使用 arc 方法可以绘制圆形或圆弧,通过设置圆心坐标、半径等参数,可以实现完整圆形和部分圆弧的绘制。

@Entry
@Component
struct CircleCanvasExample {
   
  build() {
   
    Column() {
   
      Canvas(this.context)
        .width('100%')
        .height(600)
        .onReady(() => {
   
          // 设置填充颜色为绿色
          this.context.fillStyle = '#00FF00';
          // 开始绘制路径
          this.context.beginPath();
          // 绘制圆形,指定圆心坐标、半径、起始角度和结束角度
          this.context.arc(300, 300, 100, 0, 2 * Math.PI);
          // 填充圆形
          this.context.fill();
        });
    }
  }

  private context: CanvasRenderingContext2D = new CanvasRenderingContext2D();
}

效果示例:在画布上绘制一个绿色填充的圆形。

Screenshot_2024-11-01T225947.png


三、路径绘制

通过 Canvas 中的路径绘制方法可以创建更复杂的自定义图形。可以使用 beginPathmoveTolineTo 等方法绘制路径,并使用 fillstroke 设置填充或边框样式。

3.1 绘制多边形

以下代码展示了如何在 Canvas 上绘制一个简单的三角形路径。

@Entry
@Component
struct PathCanvasExample {
   
  build() {
   
    Column() {
   
      Canvas(this.context)
        .width('100%')
        .height(600)
        .onReady(() => {
   
          // 设置路径边框颜色为红色
          this.context.strokeStyle = '#FF0000';
          // 设置路径边框宽度为 3
          this.context.lineWidth = 5;
          // 开始绘制路径
          this.context.beginPath();
          this.context.moveTo(200, 100); // 顶点 1
          this.context.lineTo(300, 500); // 顶点 2
          this.context.lineTo(100, 500); // 顶点 3
          this.context.closePath(); // 闭合路径
          // 绘制路径边框
          this.context.stroke();
        });
    }
  }

  private context: CanvasRenderingContext2D = new CanvasRenderingContext2D();
}

效果示例:在画布上绘制一个红色边框的三角形路径。

Screenshot_2024-11-01T230020.pngScreenshot_2024-11-01T230020.png


四、文本绘制

Canvas 组件中,可以通过 fillText 绘制文本,适用于显示标题、标注等文字信息。可以设置字体大小、颜色等属性。

4.1 绘制文本

使用 fillText 方法在 Canvas 中绘制文本,并设置字体、颜色等样式。

@Entry
@Component
struct TextCanvasExample {
   
  build() {
   
    Column() {
   
      Canvas(this.context)
        .width('100%')
        .height('100%')
        .onReady(() => {
   
          // 设置字体样式和大小
          this.context.font = '72px sans-serif';
          // 设置文本颜色为紫色
          this.context.fillStyle = '#800080';
          // 绘制文本
          this.context.fillText('Hello HarmonyOS!', 150, 350);
        });
    }
  }

  private context: CanvasRenderingContext2D = new CanvasRenderingContext2D();
}

效果示例:在画布上绘制一个紫色的文本“Hello HarmonyOS!”。

Screenshot_2024-11-01T230049.png


五、综合绘图实例:多图层绘制

以下示例展示了如何在 Canvas 组件中通过组合多个图形来创建更丰富的视觉效果,包括矩形、圆形、路径和文本的综合绘制。

@Entry
@Component
struct ComplexCanvasExample {
   
  build() {
   
    Column() {
   
      Canvas(this.context)
        .width('100%')
        .height(700)
        .onReady(() => {
   
          // 绘制背景矩形
          this.context.fillStyle = '#D3D3D3';
          this.context.fillRect(0, 0, 300, 400);

          // 绘制蓝色圆形
          this.context.fillStyle = '#0000FF';
          this.context.beginPath();
          this.context.arc(150, 100, 70, 0, 2 * Math.PI);
          this.context.fill();

          // 绘制黑色文本
          this.context.font = '24px sans-serif';
          this.context.fillStyle = '#000000';
          this.context.fillText('Canvas Demo', 85, 300);

          // 绘制红色三角形路径
          this.context.strokeStyle = '#FF0000';
          this.context.lineWidth = 3;
          this.context.beginPath();
          this.context.moveTo(75, 350);
          this.context.lineTo(225, 350);
          this.context.lineTo(150, 250);
          this.context.closePath();
          this.context.stroke();
        });
    }
  }

  private context: CanvasRenderingContext2D = new CanvasRenderingContext2D();
}

效果示例:在画布上绘制多层图形效果,包括背景矩形、蓝色圆形、黑色文本和红色三角形路径。

Screenshot_2024-11-01T230127.png


小结

本篇详细介绍了鸿蒙 Canvas 组件的基本用法,涵盖了矩形、圆形、路径和文本的绘制。通过合理运用这些基础绘图方法,开发者可以自由绘制丰富多样的图形效果,满足个性化的应用需求。


下一篇预告

在下一篇中,将进一步介绍 Canvas 组件的静态进阶应用,让 Canvas 绘制更加有趣。


上一篇: 「Mac畅玩鸿蒙与硬件19」鸿蒙UI组件篇9 - 自定义动画实现

下一篇: 「Mac畅玩鸿蒙与硬件21」鸿蒙UI组件篇11 - Canvas 组件的静态进阶应用


作者:SoraLuna
链接:https://www.nutpi.net/thread?topicId=238
來源:坚果派
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


目录
相关文章
|
12天前
|
存储 人工智能 弹性计算
阿里云弹性计算_加速计算专场精华概览 | 2024云栖大会回顾
2024年9月19-21日,2024云栖大会在杭州云栖小镇举行,阿里云智能集团资深技术专家、异构计算产品技术负责人王超等多位产品、技术专家,共同带来了题为《AI Infra的前沿技术与应用实践》的专场session。本次专场重点介绍了阿里云AI Infra 产品架构与技术能力,及用户如何使用阿里云灵骏产品进行AI大模型开发、训练和应用。围绕当下大模型训练和推理的技术难点,专家们分享了如何在阿里云上实现稳定、高效、经济的大模型训练,并通过多个客户案例展示了云上大模型训练的显著优势。
|
16天前
|
存储 人工智能 调度
阿里云吴结生:高性能计算持续创新,响应数据+AI时代的多元化负载需求
在数字化转型的大潮中,每家公司都在积极探索如何利用数据驱动业务增长,而AI技术的快速发展更是加速了这一进程。
|
7天前
|
并行计算 前端开发 物联网
全网首发!真·从0到1!万字长文带你入门Qwen2.5-Coder——介绍、体验、本地部署及简单微调
2024年11月12日,阿里云通义大模型团队正式开源通义千问代码模型全系列,包括6款Qwen2.5-Coder模型,每个规模包含Base和Instruct两个版本。其中32B尺寸的旗舰代码模型在多项基准评测中取得开源最佳成绩,成为全球最强开源代码模型,多项关键能力超越GPT-4o。Qwen2.5-Coder具备强大、多样和实用等优点,通过持续训练,结合源代码、文本代码混合数据及合成数据,显著提升了代码生成、推理和修复等核心任务的性能。此外,该模型还支持多种编程语言,并在人类偏好对齐方面表现出色。本文为周周的奇妙编程原创,阿里云社区首发,未经同意不得转载。
|
13天前
|
人工智能 运维 双11
2024阿里云双十一云资源购买指南(纯客观,无广)
2024年双十一,阿里云推出多项重磅优惠,特别针对新迁入云的企业和初创公司提供丰厚补贴。其中,36元一年的轻量应用服务器、1.95元/小时的16核60GB A10卡以及1元购域名等产品尤为值得关注。这些产品不仅价格亲民,还提供了丰富的功能和服务,非常适合个人开发者、学生及中小企业快速上手和部署应用。
|
2天前
|
云安全 存储 弹性计算
|
4天前
|
云安全 人工智能 自然语言处理
|
8天前
|
人工智能 自然语言处理 前端开发
用通义灵码,从 0 开始打造一个完整APP,无需编程经验就可以完成
通义灵码携手科技博主@玺哥超carry 打造全网第一个完整的、面向普通人的自然语言编程教程。完全使用 AI,再配合简单易懂的方法,只要你会打字,就能真正做出一个完整的应用。本教程完全免费,而且为大家准备了 100 个降噪蓝牙耳机,送给前 100 个完成的粉丝。获奖的方式非常简单,只要你跟着教程完成第一课的内容就能获得。
|
23天前
|
自然语言处理 数据可视化 前端开发
从数据提取到管理:合合信息的智能文档处理全方位解析【合合信息智能文档处理百宝箱】
合合信息的智能文档处理“百宝箱”涵盖文档解析、向量化模型、测评工具等,解决了复杂文档解析、大模型问答幻觉、文档解析效果评估、知识库搭建、多语言文档翻译等问题。通过可视化解析工具 TextIn ParseX、向量化模型 acge-embedding 和文档解析测评工具 markdown_tester,百宝箱提升了文档处理的效率和精确度,适用于多种文档格式和语言环境,助力企业实现高效的信息管理和业务支持。
3972 5
从数据提取到管理:合合信息的智能文档处理全方位解析【合合信息智能文档处理百宝箱】
|
12天前
|
算法 安全 网络安全
阿里云SSL证书双11精选,WoSign SSL国产证书优惠
2024阿里云11.11金秋云创季活动火热进行中,活动月期间(2024年11月01日至11月30日)通过折扣、叠加优惠券等多种方式,阿里云WoSign SSL证书实现优惠价格新低,DV SSL证书220元/年起,助力中小企业轻松实现HTTPS加密,保障数据传输安全。
537 3
阿里云SSL证书双11精选,WoSign SSL国产证书优惠
|
11天前
|
数据采集 人工智能 API
Qwen2.5-Coder深夜开源炸场,Prompt编程的时代来了!
通义千问团队开源「强大」、「多样」、「实用」的 Qwen2.5-Coder 全系列,致力于持续推动 Open Code LLMs 的发展。

热门文章

最新文章