精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

OpenHarmony - ArkUI(TS)聲明式開(kāi)發(fā)之畫(huà)板

系統(tǒng) OpenHarmony
因?yàn)镺penHarmony的API相對(duì)于HarmonyOS的API,功能上比較完善和成熟的,有些新的技術(shù)也早早接觸到,所以本項(xiàng)目直接使用OpenHarmony SDK開(kāi)發(fā)。

??想了解更多關(guān)于開(kāi)源的內(nèi)容,請(qǐng)?jiān)L問(wèn):??

??51CTO 開(kāi)源基礎(chǔ)軟件社區(qū)??

??https://ost.51cto.com??

項(xiàng)目介紹

本項(xiàng)目基于??OpenHarmony???的ArkUI框架:TS擴(kuò)展的聲明式開(kāi)發(fā)范式,關(guān)于語(yǔ)法和概念直接看官網(wǎng)官方文檔地址:??基于TS擴(kuò)展的聲明式開(kāi)發(fā)范式??,因?yàn)镺penHarmony的API相對(duì)于HarmonyOS的API,功能上比較完善和成熟的,有些新的技術(shù)也早早接觸到,所以本項(xiàng)目直接使用OpenHarmony SDK開(kāi)發(fā)。

工具版本: DevEco Studio 3.0 Beta4。

SDK版本: 3.1.6.6(API Version 8 Release)。

項(xiàng)目功能: 1、畫(huà)筆功能:可設(shè)置畫(huà)筆粗細(xì)和顏色;2、橡皮擦功能:可設(shè)置粗細(xì);3、撤回和回撤功能;4:清空畫(huà)板功能。

文件說(shuō)明

OpenHarmony - ArkUI(TS)聲明式開(kāi)發(fā)之畫(huà)板-開(kāi)源基礎(chǔ)軟件社區(qū)

效果演示

OpenHarmony - ArkUI(TS)聲明式開(kāi)發(fā)之畫(huà)板-開(kāi)源基礎(chǔ)軟件社區(qū)

用到的API

畫(huà)布組件canvas:畫(huà)布組件,用于自定義繪制圖形。

方法/屬性

解釋

beginPath()

創(chuàng)建一個(gè)新的繪制路徑

moveTo()

路徑從當(dāng)前點(diǎn)移動(dòng)到指定點(diǎn)

lineTo()

從當(dāng)前點(diǎn)到指定點(diǎn)進(jìn)行路徑連接

stroke()

進(jìn)行邊框繪制操作

clearRect()

清空畫(huà)布

strokeStyle

屬性:設(shè)置描邊的顏色

lineWidth

屬性:設(shè)置繪制線條的寬度

globalCompositeOperation

屬性:設(shè)置合成操作的方式

實(shí)現(xiàn)思路

1、畫(huà)筆功能

使用onTouch方法,監(jiān)聽(tīng)觸摸事件,手指按下:使用方法moveTo記錄起點(diǎn),手指移動(dòng):使用方法beginPath創(chuàng)建新的路徑,lineTo記錄移動(dòng)的點(diǎn),并繪制。

(代碼片段,詳細(xì)請(qǐng)查看源碼):

/**
* 觸摸事件
*/
onTouchEvent(event: TouchEvent) {
// x坐標(biāo)
const x = event.touches[0].x
// y坐標(biāo)
const y = event.touches[0].y
switch (event.type) {
case TouchType.Down: // 手指按下
{
// 創(chuàng)建一個(gè)新的繪制路徑
this.crc.beginPath()
// 設(shè)置起點(diǎn)坐標(biāo)
this.crc.moveTo(x, y)
}
break;
case TouchType.Move: // 手指移動(dòng)
case TouchType.Up: // 手指抬起
{
// 設(shè)置移動(dòng)點(diǎn)
this.crc.lineTo(x, y)
// 進(jìn)行路徑繪制
this.crc.stroke()
}
break;
default:
break;
}
}

2、橡皮擦功能

設(shè)置繪制屬性:globalCompositeOperation。

畫(huà)筆設(shè)置此屬性值: source-over (默認(rèn)值 在現(xiàn)有繪制內(nèi)容上顯示新繪制內(nèi)容),橡皮擦設(shè)置此屬性值: destination-out ( 在新繪制內(nèi)容外顯示現(xiàn)有繪制內(nèi)容)。

// 新內(nèi)容在之前內(nèi)容的之上
this.crc.globalCompositeOperation = 'source-over'
// 新內(nèi)容與之前內(nèi)容相交位置變透明
this.crc.globalCompositeOperation = 'destination-out'

3、撤回和回撤功能

數(shù)據(jù)類,記錄每次繪制的信息,線顏色、寬度、坐標(biāo)點(diǎn)集合,每次畫(huà)完保存到數(shù)組中。

/**
* 繪制信息
* @param lineColor 線顏色
* @param lineWidth 線寬度
* @param listCoord 坐標(biāo)點(diǎn)集合
*/
export class DrawInfoModel {
// 是否為畫(huà)筆,是:畫(huà)筆,否:橡皮擦
// 根據(jù)此字段設(shè)置繪制屬性:合成操作globalCompositeOperation
isPen: boolean;
// 線顏色
lineColor: string;
// 線寬度
lineWidth: number;
// 坐標(biāo)點(diǎn)集合
listCoord: Array<Coord>;
constructor(isPen: boolean, lineColor: string, lineWidth: number, listCoord: Array<Coord>) {
this.isPen = isPen;
this.lineColor = lineColor;
this.lineWidth = lineWidth;
this.listCoord = listCoord;
}
}
/**
* 坐標(biāo)點(diǎn)
* @param x 坐標(biāo)點(diǎn)x
* @param y 坐標(biāo)點(diǎn)y
*/
export class Coord {
// 坐標(biāo)點(diǎn)x
x: number;
// 坐標(biāo)點(diǎn)y
y: number;
constructor(x: number, y: number) {
this.x = x;
this.y = y;
}
}

每次繪制的信息,保存在數(shù)組中,在點(diǎn)擊撤回時(shí),撤回?cái)?shù)+1;回撤時(shí),撤回?cái)?shù)-1,并截取數(shù)組,清空畫(huà)布,遍歷數(shù)組繪制筆畫(huà)信息。

(代碼片段,詳細(xì)請(qǐng)查看源碼):

/**
* 撤回
*/
revocation() {
this.listTempXY = this.listAllXY
......
// 根據(jù)撤回的個(gè)數(shù),截取數(shù)組
this.listTempXY = this.listTempXY.slice(0, this.listTempXY.length - this.revocationNumber)
// 清空畫(huà)布
this.crc.clearRect(0, 0, this.canvasWidth, this.canvasHeight)

// 拼接筆畫(huà)路徑
for (const drawInfo of this.listTempXY) {
// 創(chuàng)建一個(gè)新的繪制路徑
this.crc.beginPath()
// 設(shè)置線顏色
this.crc.strokeStyle = drawInfo.lineColor
// 設(shè)置線寬度
this.crc.lineWidth = drawInfo.lineWidth
// 設(shè)置繪制的坐標(biāo)點(diǎn)
for (let i = 0;i < drawInfo.listCoord.length; i++) {
const coord = drawInfo.listCoord[i]
// 第一個(gè)設(shè)置為起點(diǎn)
if (i === 0) {
this.crc.moveTo(coord.x, coord.y)
} else {
this.crc.lineTo(coord.x, coord.y)
}
}
// 進(jìn)行路徑繪制
this.crc.stroke()
}
}

總結(jié)

此項(xiàng)目并沒(méi)有特別復(fù)雜的地方,注釋也很詳細(xì),以上列出的代碼都是實(shí)現(xiàn)主要的功能,其他細(xì)節(jié)請(qǐng)查看源碼,最后不得不感慨聲明式語(yǔ)法的強(qiáng)大和簡(jiǎn)潔性,完成此功能相對(duì)于使用JS來(lái)實(shí)現(xiàn)效率提升很高,也希望鴻蒙社區(qū)越來(lái)越好,融入更多的熱愛(ài)者。

??想了解更多關(guān)于開(kāi)源的內(nèi)容,請(qǐng)?jiān)L問(wèn):??

??51CTO 開(kāi)源基礎(chǔ)軟件社區(qū)??

??https://ost.51cto.com??。

責(zé)任編輯:jianghua 來(lái)源: 鴻蒙社區(qū)
相關(guān)推薦

2022-08-08 19:46:26

ArkUI鴻蒙

2022-09-02 15:17:04

ArkUI鴻蒙

2022-09-26 15:16:03

ArkUITS

2022-07-20 15:32:25

時(shí)鐘翻頁(yè)Text組件

2022-04-08 14:47:11

ArkUI列表字母索引鴻蒙

2022-08-24 16:08:22

ETS鴻蒙

2022-01-07 09:56:16

鴻蒙HarmonyOS應(yīng)用

2023-08-17 15:04:22

2021-11-26 15:31:43

鴻蒙HarmonyOS應(yīng)用

2022-11-21 16:15:41

ArkUI鴻蒙

2023-05-30 14:50:20

界面開(kāi)發(fā)鴻蒙

2022-08-12 19:13:07

etswifi連接操作

2024-01-11 15:54:55

eTS語(yǔ)言TypeScript應(yīng)用開(kāi)發(fā)

2021-12-08 10:07:13

鴻蒙HarmonyOS應(yīng)用

2021-12-03 09:49:59

鴻蒙HarmonyOS應(yīng)用

2023-08-17 15:01:08

ArkUI布局渲染

2021-12-01 10:02:57

鴻蒙HarmonyOS應(yīng)用

2022-09-16 15:34:32

CanvasArkUI

2022-02-25 15:08:06

DevEco開(kāi)發(fā)OpenHarmon鴻蒙

2022-07-26 14:40:42

ArkUIJS
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

无码播放一区二区三区| 俄罗斯精品一区二区三区| 麻豆av免费观看| 日韩成人亚洲| 亚洲免费视频成人| 国产一区视频观看| 欧美一级黄视频| 欧美fxxxxxx另类| 日韩毛片在线观看| www.桃色.com| jizz内谢中国亚洲jizz| 中文字幕一区二区三区在线观看| 成人羞羞视频免费| 久久国产香蕉视频| 亚洲一级电影| 日韩有码视频在线| 国产又黄又粗又猛又爽的视频| 91成人抖音| 午夜激情综合网| 中文字幕精品一区日韩| 三级毛片在线免费看| 国内成人免费视频| 日韩美女免费线视频| 青青操国产视频| 日韩在线综合| 亚洲一二在线观看| 国产伦精品一区二区三区精品| 久久91视频| 色婷婷精品大在线视频| 成年女人18级毛片毛片免费| 欧美jizzhd69巨大| 国产亚洲1区2区3区| 国产日韩精品一区观看| 国产农村妇女毛片精品久久| 日韩不卡一二三区| 91wwwcom在线观看| 国产真实乱偷精品视频| 国产精品精品国产一区二区| 亚洲最大中文字幕| japanese中文字幕| 欧美日韩一区二区三区在线电影| 日韩欧美一区二区在线视频| 三上悠亚av一区二区三区| 亚洲承认视频| 日本道精品一区二区三区| www.xxx麻豆| 欧美黑人xx片| 亚洲综合色视频| 久久久久久久久久伊人| 老司机在线视频二区| 国产精品美女久久久久久2018| 欧美极品jizzhd欧美| 欧美美乳在线| 国产亚洲精品中文字幕| 日本不卡二区高清三区| 免费在线看v| 久久亚洲精品小早川怜子| 久久久com| 日韩电影网址| 国产女同性恋一区二区| 亚洲精品永久www嫩草| 91激情在线| 亚洲欧美一区二区三区孕妇| 日本丰满大乳奶| 3d玉蒲团在线观看| 夜夜夜精品看看| 久久综合亚洲精品| 91www在线| 一本到高清视频免费精品| 久久精品.com| 久久日本片精品aaaaa国产| 欧美日韩另类国产亚洲欧美一级| 手机版av在线| jizz国产精品| 亚洲欧美日韩一区二区在线 | 久久亚洲春色中文字幕久久久| 精品午夜一区二区三区| 黄色小视频在线免费观看| 国产精品成人免费| 久草视频这里只有精品| 午夜av不卡| 欧美日韩在线一区二区| 青青草精品在线| 欧美调教在线| 色久欧美在线视频观看| 免费一级a毛片夜夜看 | 久久成人高清| 成人免费观看男女羞羞视频| 国产精品免费一区二区三区观看| 日本五码在线| 一区在线观看视频| 国产3p露脸普通话对白| 国精产品一区一区三区四川| 这里只有精品99re| 毛茸茸多毛bbb毛多视频| 精品一区二区三区中文字幕老牛| 久久夜精品香蕉| 国产精品人人人人| 国产综合色视频| 精品国产电影| 免费a级在线播放| 福利视频导航一区| 999热精品视频| 最新亚洲精品| 欧美激情亚洲一区| 中国老头性行为xxxx| 成人性生交大片免费看中文网站| 日韩电影免费观看在| 青草在线视频| 在线亚洲人成电影网站色www| 先锋资源在线视频| 日本激情一区| 欧美一区深夜视频| 国产三级视频在线播放| 国产日韩在线不卡| 91视频 -- 69xx| 日韩精品成人| 日韩在线观看免费全| 日本免费在线观看视频| 粉嫩在线一区二区三区视频| 一区二区三区久久网| 欧美一级大片| 日韩成人在线免费观看| 久久久久久久久久综合| 久久99精品久久只有精品| 日本一区高清在线视频| 91av亚洲| 日韩av在线最新| 国产精品30p| 福利一区在线观看| 男人天堂成人网| 久久精品国产福利| 伊人久久精品视频| 亚洲成人第一网站| 91免费在线视频观看| 老太脱裤让老头玩ⅹxxxx| 久久精品免视看国产成人| 中文字幕在线看视频国产欧美| 黄色片中文字幕| 91在线小视频| 精品国产免费av| 人人精品视频| 欧美在线视频播放| 日本中文字幕一区二区有码在线 | 成人毛片18女人毛片| 成人性生交大合| 老子影院午夜伦不卡大全| 亚洲免费一区三区| 欧美精品激情视频| 狠狠躁夜夜躁av无码中文幕| 亚洲午夜影视影院在线观看| 日本美女视频网站| 亚洲小说区图片区| 久久国产精品免费一区| 英国三级经典在线观看| 亚洲欧美国产精品va在线观看| 中文字幕视频网| 久久久久久99精品| 亚洲最大综合网| 久久资源中文字幕| 91综合免费在线| 激情在线视频播放| 亚洲精品xxx| 激情视频网站在线观看| 国产精品人妖ts系列视频| 中文字幕av不卡在线| 99精品一区| 国产91色在线|亚洲| 欧美aa免费在线| 国产亚洲精品91在线| 国产精品九九九九| 亚洲一区二区三区中文字幕 | 亚洲欧美影音先锋| 初高中福利视频网站| 91久久亚洲| 日本一区二区三区免费观看| 色999久久久精品人人澡69| 色综合久久天天综线观看| 亚洲日本在线播放| 欧美日韩精品高清| 国产一级在线观看视频| 久久久91精品国产一区二区三区| 午夜宅男在线视频| 欧美日韩精品| 青青草成人激情在线| 96sao精品免费视频观看| 欧美劲爆第一页| 国产二区视频在线观看| 欧美一区二区三区视频免费 | 免费美女久久99| 青青在线视频免费观看| 亚洲理论电影| 91丨九色丨国产在线| 免费看男女www网站入口在线| 最好看的2019年中文视频| 好吊色视频一区二区| 欧美性大战久久久久久久蜜臀| 校园春色 亚洲| 久久久亚洲精品石原莉奈| 国产欧美激情视频| 亚洲免费综合| 精品无码av无码免费专区| 免费av一区| 成人欧美一区二区三区在线观看| 久久99久久99精品免观看软件| 欧美丰满少妇xxxx| 在线中文资源天堂| 亚洲开心激情网| 性网爆门事件集合av| 欧美日韩精品专区| 东京热一区二区三区四区| 亚洲一区在线视频观看| 国产又粗又长又黄的视频| 97精品国产露脸对白| 欧美性猛交xx| 美女视频一区二区三区| 岳毛多又紧做起爽| 禁久久精品乱码| 欧洲金发美女大战黑人| 婷婷久久一区| 亚洲 日韩 国产第一区| 亚洲成aⅴ人片久久青草影院| 91嫩草国产在线观看| 日本午夜免费一区二区| 国产精品av电影| 亚洲欧洲自拍| 韩国欧美亚洲国产| 欧美xxxbbb| 欧美成年人视频网站欧美| 在线播放毛片| 中文字幕久热精品在线视频| 激情在线视频| 精品一区二区三区四区| 天堂av在线播放| 日韩成人在线视频网站| 天堂中文在线视频| 亚洲精品国产电影| 午夜影院免费视频| 亚洲国产成人在线播放| 欧美一级特黄aaaaaa大片在线观看 | 中文字幕亚洲欧美一区二区三区 | 久久精品电影网站| eeuss影院www在线观看| 一区二区三区在线播放欧美| 国内精品一区视频| 亚洲一区二区精品| 成人免费在线视频网| 一区二区国产精品视频| h视频在线免费| 色偷偷偷亚洲综合网另类| av在线第一页| 久久偷看各类女兵18女厕嘘嘘| 免费**毛片在线| 久久这里只有精品视频首页| av在线免费网站| 欧美高跟鞋交xxxxhd| xxxx在线视频| 日本一区二区在线播放| 日韩国产网站| 成人国产精品色哟哟| 亚洲成人偷拍| 久久99久久精品国产| 精品国产精品| 日韩视频在线免费播放| 欧美午夜精品| 欧美xxxxx在线视频| 蜜臀av国产精品久久久久| 午夜激情影院在线观看| 国产69精品久久777的优势| 一级欧美一级日韩片| 国产亚洲精品bt天堂精选| 在线免费看av网站| 亚洲国产综合91精品麻豆| 五月天婷婷久久| 欧美午夜一区二区| www.超碰在线.com| 日韩精品亚洲视频| 一区二区三区视频网站| 欧美国产日本高清在线| 蜜桃成人精品| 99久久国产免费免费| 久久91麻豆精品一区| 不卡中文字幕在线| 一区二区三区精品视频在线观看| 午夜dv内射一区二区| 国产另类ts人妖一区二区| 国产肉体xxxx裸体784大胆| 国产精品色呦呦| 国产在线拍揄自揄拍| 欧美午夜片在线看| 欧美 日韩 国产 成人 在线| 亚洲日本欧美中文幕| 18网站在线观看| 日韩美女视频免费看| 亚洲三级av| 亚洲精品8mav| 中国女人久久久| 国产又粗又长又爽又黄的视频| 91原创在线视频| 欧美日韩精品在线观看视频| 欧洲av在线精品| 天堂av2024| 久操成人在线视频| 国产成人精品亚洲日本在线观看| 91精品久久久久久蜜桃| 日韩免费在线| 97av视频在线观看| 不卡视频一二三四| 欧美三级黄色大片| 色老头久久综合| 婷婷色在线观看| 欧美大胆a视频| 成人福利一区二区| 麻豆久久久9性大片| 好看的av在线不卡观看| 国产免费中文字幕| 国产精品丝袜在线| 中文字幕一区在线播放| 亚洲精品成人久久| 日本片在线看| 亚洲一区二区三区四区在线播放| 精品久久视频| 成人观看免费完整观看| av高清不卡在线| 久久久99精品| 日韩手机在线导航| 3d成人动漫在线| 国产精品精品视频| 一区二区三区视频免费观看| 日本a在线免费观看| 国产精品888| 国内偷拍精品视频| 欧美一级视频精品观看| 成人在线播放免费观看| 国产精品自产拍在线观看中文| 国产欧美日韩精品高清二区综合区| 男人添女荫道口图片| 丁香亚洲综合激情啪啪综合| 黄色一级视频免费观看| 欧美一级xxx| 日本动漫同人动漫在线观看| 91免费在线观看网站| 欧美天天视频| 超碰caoprom| 精品久久久久久亚洲国产300| 欧美一区二区在线观看视频| 欧美极品第一页| 欧美成人专区| 日日碰狠狠躁久久躁婷婷| 久久蜜桃av一区精品变态类天堂| 天堂网av手机版| 亚洲新声在线观看| 成人在线视频免费| 致1999电视剧免费观看策驰影院| 久久超碰97中文字幕| 欧美成人精品激情在线视频| 日韩一级在线观看| 草莓视频丝瓜在线观看丝瓜18| 国产欧美日韩一区二区三区| 国产精品久久久免费| 谁有免费的黄色网址| 欧美剧在线免费观看网站 | 色婷婷综合在线观看| 一区二区三区四区五区视频在线观看| 亚洲风情第一页| 91大神福利视频在线| 精品国产aⅴ| 四川一级毛毛片| 欧美午夜影院在线视频| 国产福利在线视频| 91在线观看免费观看| 99精品久久| 一级黄色片网址| 欧美一激情一区二区三区| 九色porny自拍视频在线播放| 日韩高清av电影| 国产精品资源在线看| 影音先锋亚洲天堂| 日日骚久久av| 91精品导航| 成人性生生活性生交12| 日韩毛片一二三区| 五月婷婷丁香六月| 国产精品亚洲激情| 精品成人一区| 久久婷婷五月综合| 日韩精品最新网址| 欧美日韩大片| 青青青在线观看视频| 国产三级欧美三级日产三级99| www.av导航| 国产精品久久久久久av| 亚洲国产精品一区| 国产中文字幕久久| 日韩精品视频在线观看网址| 日韩电影精品| 日韩免费毛片视频| 亚洲综合色成人| 久操视频在线观看| 欧美精品一区二区视频|