「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.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
來源:坚果派
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


目录
相关文章
|
14天前
「Mac畅玩鸿蒙与硬件51」UI互动应用篇28 - 模拟记账应用
本篇教程将介绍如何创建一个模拟记账应用,通过账单输入、动态列表展示和实时统计功能,学习接口定义和组件间的数据交互。
132 68
|
14天前
|
UED
「Mac畅玩鸿蒙与硬件52」UI互动应用篇29 - 模拟火车票查询系统
本篇教程将实现一个模拟火车票查询系统,通过输入条件筛选车次信息,并展示动态筛选结果,学习事件处理、状态管理和界面展示的综合开发技巧。
51 13
|
13天前
「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用
本篇教程将实现一个打卡提醒小应用,通过用户输入时间进行提醒设置,并展示实时提醒状态,实现提醒设置和取消等功能。
46 10
【鸿蒙 HarmonyOS】UI 组件 ( 拖动条 Slider 组件 )
【鸿蒙 HarmonyOS】UI 组件 ( 拖动条 Slider 组件 )
413 0
【鸿蒙 HarmonyOS】UI 组件 ( 拖动条 Slider 组件 )
|
XML Java 数据格式
HarmonyOS学习路之开发篇—Java UI框架(自定义组件与布局 二)
自定义布局 当Java UI框架提供的布局无法满足需求时,可以创建自定义布局,根据需求自定义布局规则
|
XML 前端开发 Java
HarmonyOS学习路之开发篇—Java UI框架(自定义组件与布局 一)
HarmonyOS提供了一套复杂且强大的Java UI框架,其中Component提供内容显示,是界面中所有组件的基类。ComponentContainer作为容器容纳Component或ComponentContainer对象,并对它们进行布局。
|
XML JavaScript 前端开发
HarmonyOS学习路之开发篇—Java UI框架(基础组件说明【三】)
接上一篇文章… 上两篇文章已经介绍了大部分的Java UI组件 ,因为时间关系把一个内容分为了三个部分,这是最后一篇组件的介绍。分别介绍ListContainer、ScrollView和WebView。
|
XML Java 数据格式
HarmonyOS学习路之开发篇—Java UI框架(基础组件说明【二】)
二、分类说明 ④Picker Picker提供了滑动选择器,允许用户从预定义范围中进行选择。 Picker的自有XML属性见下表:
|
XML Java Android开发
HarmonyOS学习路之开发篇—— Java UI框架(基础组件说明【一】)
HarmonyOS的常用组件一般在resources/base/layout下的xml文件中声明,然后在AbilitySlice中通过super.setUIContent(ResourceTable.某layout布局的文件名)来加载布局。在AbilitySlice中通过super.findComponentById(ResourceTable.组件的id)获取组件,获取成功后就可以对该组件进行操作,如添加监听,设置内容等。当然也可以通过代码动态的使用控件。
|
XML Java 数据格式
HarmonyOS学习路之开发篇—— Java UI框架(组件与布局说明)
UI即使用在屏幕上显示的用户界面,该界面用来显示所有可能被用户查看和操作的内容。

热门文章

最新文章