当前位置: 首页 > web >正文

HarmonyOS NEXT仓颉开发语言实现画板案例

大家上午好,今天分享一下仓颉开发语言实现的画板案例。

最近总是有同学说我写ArkTS冒充仓颉,为了自证清白,截图给大家看一下,确实是仓颉文件:

仓颉提供了画布组件Canvas,我们所有的绘制工作都要在画布上进行,所以首先在页面添加一个足够大的画布组件:

Canvas(this.context)
.backgroundColor(0xffff00)
.width(100.percent)
.height(100.percent)

看到上面的代码,大家可能会问this.context是什么,幽蓝君将它比作画笔,使用画笔在画布上作画,context可以绘制图形、文本、图片等内容。画笔的样式是可以修改的,比如粗细、颜色等等:

var settings: RenderingContextSettings = RenderingContextSettings(antialias: true)
var context: CanvasRenderingContext2D = CanvasRenderingContext2D(this.settings)
var path2Db: Path2D = Path2D()protected open func onPageShow(){context.lineWidth(5)context.strokeStyle(0x0000ff)
}

今天我们做的是让画笔跟随我们触摸过的轨迹绘制曲线。

要实现这个需求,首先我们需要知道绘制国的轨迹坐标,才能在画布上准确的绘制。

为了让绘制更加准确,我使用了三次贝塞尔曲线,这样我需要记录下至少两个点,然后将这个点的中点也传入贝塞尔曲线的坐标。

触摸滑动事件可以使用onTouch,onTouch的事件有几种类型,如Down、Move等,在仓颉中对类型我使用了非常规的判断方式:

.onTouch({e:TouchEvent =>var pointX = e.touches[0].x;var pointY = e.touches[0].y;if(e.eventType.toString() == 'Move'){let curX = (pointX + this.pointX1)/Float64(2)let curY = (pointY + this.pointY1)/Float64(2)this.path2Db.bezierCurveTo(this.pointX1,this.pointY1,this.pointX2,this.pointY2,curX,curY)this.pointX1 = pointXthis.pointY1 = pointYthis.pointX2 = curXthis.pointY2 = curYthis.context.stroke(this.path2Db)}else if(e.eventType.toString() == 'Down'){this.path2Db.moveTo(e.touches[0].x, e.touches[0].y);this.pointX1 = pointXthis.pointY1 = pointYthis.pointX2 = pointXthis.pointY2 = pointY}})

实现绘制曲线后,可以使用clearRect方法实现对画布的清空。

Button('清空').onClick({e =>  this.context.clearRect(0, 0, 3000, 3000)})

这样一个简单的画板效果就实现啦,感谢阅读。​​#​​​​#HarmonyOS语言​​##仓颉##休闲娱乐#

http://www.xdnf.cn/news/14765.html

相关文章:

  • Python爬虫实战:研究Levenshtein库相关技术
  • FrozenBatchNorm2d 详解
  • Win10安装dify
  • AI+时代已至|AI人才到底该如何培育?
  • 跨越十年的C++演进:C++14新特性全解析
  • [论文阅读] 人工智能+ | 用大语言模型给建筑合规检查“开挂“:BIM领域的自动化革命
  • Unity2D 街机风太空射击游戏 学习记录 #14 环射和散射组合 循环屏幕道具
  • mysql无法启动的数据库迁移
  • 从提示工程(Prompt Engineering)到上下文工程(Context Engineering)
  • 力扣-合并区间
  • 蜂鸟代理IP+云手机:跨境电商多账号运营的“隐形风控引擎”
  • 供应链管理:供应链计划主要计算公式/方法
  • 使用 ReAct 框架在 Ollama 中实现本地代理(Agent)
  • Linux 驱动开发详解:从入门到实践
  • 易拓SAP培训分享:身为SAP顾问,应当了解哪些ABAP开发知识?
  • 强化学习理论基础:从Q-learning到PPO的算法演进(1)
  • Java课后习题(编程题)
  • Spring Cloud Ribbon核心负载均衡算法详解
  • 《高等数学》(同济大学·第7版)第九章 多元函数微分法及其应用第一节多元函数的基本概念
  • Android14音频子系统-ASoC-ALSA之DAPM电源管理子系统
  • MQTT 客户端(MQTT Client)工具介绍及分享
  • 【DataWhale组队学习】AI办公实践与应用-数据分析
  • MySQL之视图深度解析
  • 大塘至浦北高速分布式光伏项目,让‘交通走廊’变身‘绿色能源带’
  • RabbitMq中启用NIO
  • TDengine 的 CASE WHEN 语法技术详细
  • AES加密:为你的PDF文档加上一道钢铁防线
  • 在uni-app build的index.html 中加入 <mate,和title 等标签内容 内容
  • JSON-LD技术深度解析:从语义网理想到现实应用的完整指南(JSON和知识图谱的桥梁)
  • 阿里云OSS文件上传完整实现方案