个人网站有哪些站西安建站平台

web/2025/10/1 12:45:23/文章来源:
个人网站有哪些站,西安建站平台,高端品牌化妆品排行榜前十名,潍坊 互联网公司介绍 本示例使用drawing库的Pen和Path结合NodeContainer组件实现手写绘制功能。手写板上完成绘制后#xff0c;通过调用image库的packToFile和packing接口将手写板的绘制内容保存为图片#xff0c;并将图片文件保存在应用沙箱路径中。 效果图预览 使用说明 在虚线区域手写…介绍 本示例使用drawing库的Pen和Path结合NodeContainer组件实现手写绘制功能。手写板上完成绘制后通过调用image库的packToFile和packing接口将手写板的绘制内容保存为图片并将图片文件保存在应用沙箱路径中。 效果图预览 使用说明 在虚线区域手写绘制点击撤销按钮撤销前一笔绘制点击重置按钮清空绘制。点击packToFile保存图片按钮和packing保存图片按钮可以将绘制内容保存为图片写入文件显示图片的沙箱路径。 实现思路 创建NodeController的子类MyNodeController用于获取根节点的RenderNode和绑定的NodeContainer组件宽高。 export class MyNodeController extends NodeController {private rootNode: FrameNode | null null; // 根节点rootRenderNode: RenderNode | null null; // 从NodeController根节点获取的RenderNode用于添加和删除新创建的MyRenderNode实例width: number 0; // 实例绑定的NodeContainer组件的宽单位pxheight: number 0; // 实例绑定的NodeContainer组件的宽单位px// MyNodeController实例绑定的NodeContainer创建时触发创建根节点rootNode并将其挂载至NodeContainermakeNode(uiContext: UIContext): FrameNode {this.rootNode new FrameNode(uiContext);if (this.rootNode ! null) {this.rootRenderNode this.rootNode.getRenderNode();}return this.rootNode;}// 绑定的NodeContainer布局时触发获取NodeContainer的宽高aboutToResize(size: Size): void {this.width size.width;this.height size.height;// 设置画布底色为白色if (this.rootRenderNode ! null) {// NodeContainer布局完成后设置rootRenderNode的背景色为白色this.rootRenderNode.backgroundColor 0XFFFFFFFF;// rootRenderNode的位置从组件NodeContainer的左上角(0,0)坐标开始大小为NodeContainer的宽高this.rootRenderNode.frame { x: 0, y: 0, width: this.width, height: this.height };}} }创建RenderNode的子类MyRenderNode初始化画笔和绘制path路径。 export class MyRenderNode extends RenderNode {path: drawing.Path new drawing.Path(); // 新建路径对象用于绘制手指移动轨迹// RenderNode进行绘制时会调用draw方法初始化画笔和绘制路径draw(context: DrawContext): void {const canvas context.canvas;// 创建一个画笔Pen对象Pen对象用于形状的边框线绘制const pen new drawing.Pen();// 设置画笔开启反走样可以使得图形的边缘在显示时更平滑pen.setAntiAlias(true);// 设置画笔颜色为黑色const pen_color: common2D.Color { alpha: 0xFF, red: 0x00, green: 0x00, blue: 0x00 };pen.setColor(pen_color);// 开启画笔的抖动绘制效果。抖动绘制可以使得绘制出的颜色更加真实。pen.setDither(true);// 设置画笔的线宽为5pxpen.setStrokeWidth(5);// 将Pen画笔设置到canvas中canvas.attachPen(pen);// 绘制pathcanvas.drawPath(this.path);} }创建变量currentNode用于存储当前正在绘制的节点变量nodeCount用来记录已挂载的节点数量。 private currentNode: MyRenderNode | null null; // 当前正在绘制的节点private nodeCount: number 0; // 已挂载到根节点的子节点数量创建自定义节点容器组件NodeContainer接收MyNodeController的实例将自定义的渲染节点挂载到组件上实现自定义绘制。 NodeContainer(this.myNodeController).width(100%).height($r(app.integer.hand_writing_canvas_height)).onTouch((event: TouchEvent) {this.onTouchEvent(event);}).id(NODE_CONTAINER_ID)在NodeContainer组件的onTouch回调函数中手指按下创建新的节点并挂载到rootRenderNodenodeCount加一手指移动更新节点中的path对象绘制移动轨迹并将节点重新渲染。 onTouchEvent(event: TouchEvent): void {// TODO知识点在手指按下时创建新的MyRenderNode对象挂载到rootRenderNode上手指移动时根据触摸点坐标绘制线条并重新渲染节点// 获取手指触摸位置的坐标点const positionX: number vp2px(event.touches[0].x);const positionY: number vp2px(event.touches[0].y);logger.info(TAG, Touch positionX: ${positionX}, Touch positionY: ${positionY});switch (event.type) {case TouchType.Down: {// 每次手指按下创建一个MyRenderNode对象用于记录和绘制手指移动的轨迹const newNode new MyRenderNode();// 定义newNode的大小和位置位置从组件NodeContainer的左上角(0,0)坐标开始大小为NodeContainer的宽高newNode.frame { x: 0, y: 0, width: this.myNodeController.width, height: this.myNodeController.height };this.currentNode newNode;// 移动新节点中的路径path到手指按下的坐标点this.currentNode.path.moveTo(positionX, positionY);if (this.myNodeController.rootRenderNode ! null) {// appendChild在renderNode最后一个子节点后添加新的子节点this.myNodeController.rootRenderNode.appendChild(this.currentNode);// 已挂载的节点数量加一this.nodeCount;}break;}case TouchType.Move: {if (this.currentNode ! null) {// 手指移动绘制移动轨迹this.currentNode.path.lineTo(positionX, positionY);// 节点的path更新后需要调用invalidate()方法触发重新渲染this.currentNode.invalidate();}break;}case TouchType.Up: {// 手指抬起释放this.currentNodethis.currentNode null;}default: {break;}}}rootRenderNode调用getChild方法获取最后一个挂载的子节点再使用removeChild方法移除实现撤销上一笔的效果。 goBack() {if (this.myNodeController.rootRenderNode ! null this.nodeCount 0) {// getChild获取最后挂载的子节点const node this.myNodeController.rootRenderNode.getChild(this.nodeCount - 1);// removeChild移除指定子节点this.myNodeController.rootRenderNode.removeChild(node);this.nodeCount--;}}使用clearChildren清除当前rootRenderNode的所有子节点实现画布重置nodeCount清零。 resetCanvas() {if (this.myNodeController.rootRenderNode ! null this.nodeCount 0) {// 清除当前rootRenderNode的所有子节点this.myNodeController.rootRenderNode.clearChildren();this.nodeCount 0;}}使用componentSnapshot.get获取组件NodeContainer的PixelMap对象用于保存图片 componentSnapshot.get(NODE_CONTAINER_ID, async (error: Error, pixelMap: image.PixelMap) {if (pixelMap ! null) {// 图片写入文件this.filePath await this.saveFile(getContext(), pixelMap);logger.info(TAG, Images saved using the packing method are located in : ${this.filePath});}})使用image库的packToFile()和packing()将获取的PixelMap对象保存为图片并将图片文件保存在应用沙箱路径中。 ImagePacker.packToFile()可直接将PixelMap对象写入为图片。 async packToFile(context: Context, pixelMap: PixelMap): Promisestring {// 创建图像编码ImagePacker对象const imagePackerApi image.createImagePacker();// 设置编码输出流和编码参数。format为图像的编码格式quality为图像质量范围从0-100100为最佳质量const options: image.PackingOption { format: image/jpeg, quality: 100 };// 图片写入的沙箱路径const filePath: string ${context.filesDir}/${getTimeStr()}.jpg;const file: fs.File await fs.open(filePath, fs.OpenMode.CREATE | fs.OpenMode.READ_WRITE);// 使用packToFile直接将pixelMap写入文件await imagePackerApi.packToFile(pixelMap, file.fd, options);fs.closeSync(file);return filePath;}ImagePacker.packing()可获取图片的ArrayBuffer数据再使用fs将数据写入为图片。 async saveFile(context: Context, pixelMap: PixelMap): Promisestring {// 创建图像编码ImagePacker对象const imagePackerApi image.createImagePacker();// 设置编码输出流和编码参数。format为图像的编码格式quality为图像质量范围从0-100100为最佳质量const options: image.PackingOption { format: image/jpeg, quality: 100 };// 图片写入的沙箱路径const filePath: string ${context.filesDir}/${getTimeStr()}.jpg;const file: fs.File await fs.open(filePath, fs.OpenMode.READ_WRITE | fs.OpenMode.CREATE);// 使用packing打包获取图片的ArrayBufferconst data: ArrayBuffer await imagePackerApi.packing(pixelMap, options);// 将图片的ArrayBuffer数据写入文件fs.writeSync(file.fd, data);fs.closeSync(file);return filePath;}高性能知识点 不涉及 工程结构模块类型 handwritingtoimage // har类型 |---/src/main/ets/model | |---RenderNodeModel.ets // 模型层-节点数据模型 |---/src/main/ets/view | |---HandWritingToImage.ets // 视图层-手写板场景页面模块依赖 本实例依赖common模块中的日志工具类logger。 参考资料 ohos.graphics.drawing (绘制模块) NodeController 自渲染节点RenderNode ohos.multimedia.image(图片处理) ohos.file.fs(文件管理) 鸿蒙全栈开发全新学习指南 也为了积极培养鸿蒙生态人才让大家都能学习到鸿蒙开发最新的技术针对一些在职人员、0基础小白、应届生/计算机专业、鸿蒙爱好者等人群整理了一套纯血版鸿蒙HarmonyOS Next全栈开发技术的学习路线【包含了大厂APP实战项目开发】。 本路线共分为四个阶段 第一阶段鸿蒙初中级开发必备技能 第二阶段鸿蒙南北双向高工技能基础gitee.com/MNxiaona/733GH 第三阶段应用开发中高级就业技术 第四阶段全网首发-工业级南向设备开发就业技术https://gitee.com/MNxiaona/733GH 《鸿蒙 (Harmony OS)开发学习手册》共计892页 如何快速入门 1.基本概念 2.构建第一个ArkTS应用 3.…… 开发基础知识:gitee.com/MNxiaona/733GH 1.应用基础知识 2.配置文件 3.应用数据管理 4.应用安全管理 5.应用隐私保护 6.三方应用调用管控机制 7.资源分类与访问 8.学习ArkTS语言 9.…… 基于ArkTS 开发 1.Ability开发 2.UI开发 3.公共事件与通知 4.窗口管理 5.媒体 6.安全 7.网络与链接 8.电话服务 9.数据管理 10.后台任务(Background Task)管理 11.设备管理 12.设备使用信息统计 13.DFX 14.国际化开发 15.折叠屏系列 16.…… 鸿蒙开发面试真题含参考答案:gitee.com/MNxiaona/733GH 鸿蒙入门教学视频 美团APP实战开发教学gitee.com/MNxiaona/733GH 写在最后 如果你觉得这篇内容对你还蛮有帮助我想邀请你帮我三个小忙点赞转发有你们的 『点赞和评论』才是我创造的动力。关注小编同时可以期待后续文章ing不定期分享原创知识。想要获取更多完整鸿蒙最新学习资源请移步前往小编gitee.com/MNxiaona/733GH

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

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

相关文章

品牌网站建设可信大蝌蚪如何让百度收录自己的网站信息

需要绘制一条可控制的贝塞尔曲线&#xff0c;发现fabic官网中一个demo有点类似。感兴趣的可以移步官网查看demo。 官网的demo是对于html 而言的&#xff0c;放在vue中需要变换一下&#xff0c;具体代码如下&#xff1a; <template><div class"dashboard-contai…

模仿采集网站生成网页html毕业设计题目大全

一、探索未知&#xff0c;开启全新扭蛋体验 淘宝扭蛋机小程序&#xff0c;为您带来一场前所未有的扭蛋盛宴。在这个充满神秘与乐趣的平台上&#xff0c;每一次点击都将引领您走进未知的宝藏世界&#xff0c;每一次旋转都可能揭示出意想不到的惊喜。 二、海量商品&#xff0c;…

网站建设制作公司都选万维科技ios开发软件

有的网页必须登陆才能看到&#xff0c;这个时候想要抓取信息必须在header里面传递cookie值才能获取1、首先登陆网站&#xff0c;打开firebug就能看到对应的cookie把这些cookie拷贝出来就能使用了2、<?php header("Content-type:text/html;Charsetutf8");$ch curl…

设计素材网站蜂上海百度竞价托管

Xpath[转] XPath 是一门在 XML 文档中查找信息的语言。XPath 可用来在 XML 文档中对元素和属性进行遍历。 XPath 是 W3C XSLT 标准的主要元素&#xff0c;并且 XQuery 和 XPointer 同时被构建于 XPath 表达之上。 因此&#xff0c;对 XPath 的理解是很多高级 XML 应用的基础。 …

湛江快速网站建设在哪里做wordpress用户上传头像

过滤器的执行过程&#xff1a;// 目标资源执行前执行chain.doFilter(request, response);// 目标资源执行后执行文件上传的前提&#xff1a;1.表单的method方法必须是post2.表单的enctype类型必须是&#xff1a;multipart/form-data3.表单中input的上传输入域为&#xff1a;<…

性男女做视频观看网站世界500强企业排名

回文数 给你一个整数 x &#xff0c;如果 x 是一个回文整数&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。回文数是指正序&#xff08;从左向右&#xff09;和倒序&#xff08;从右向左&#xff09;读都是一样的整数。 示例 1&#xff1a; 输入&#xff1…

温州定制网站建设电话微网站怎么做百度关键词排名

我通过了&#xff0c;当然。 封闭的电子考场&#xff0c;在场外待考的人们不惜屈尊偷看场内的“考题”&#xff0c;不过想来也没有什么看的&#xff0c;不还是平常一样的正反手进出库和移库嘛。 8:30正式开考之前&#xff0c;可以买票&#xffe5;10练习一次&#xff0c;有一位…

光伏电站建设的国家网站百度贴吧广告投放价格

如果你有多个List对象&#xff0c;想要将它们合并成一个List对象&#xff0c;可以使用addAll()方法来实现。addAll()方法将会把一个List中的元素逐个添加到另一个List中。 以下是一个示例&#xff0c;展示了如何将多个List对象合并为一个List对象&#xff1a; import java.ut…

青岛做网站eoe潍坊专业人员继续教育网络平台登录

文章目录 上一篇约束极值问题的最优性条件基本概念一般情况的约束类型最优化条件 上一篇 最优化理论分析复习–最优性条件&#xff08;一&#xff09; 约束极值问题的最优性条件 基本概念 凸规划 m i n f ( x ) min f(x) minf(x) s . t . { g i ( x ) ≥ 0 &#xff0c; …

网站建设类公司可以拿哪些项目资金东莞厚街天气

在软件开发领域&#xff0c;GitOps 和 DevOps 是加强协作和实现软件交付流程自动化的重要技术。虽然这两种模式都旨在提高软件开发生命周期的效率&#xff0c;但它们的核心原则和实施方式却各不相同。 本篇文章将帮助您了解 GitOps 和 DevOps 之间的差异、它们的工作流程&am…

带m开头的网站怎么做wordpress首页按钮

📃个人主页:个人主页 🔥系列专栏:C语言试题200例目录 💬推荐一款刷算法、笔试、面经、拿大公司offer神器 👉 点击跳转进入网站 ✅作者简介:大家好,我是码莎拉蒂,CSDN博客专家(全站排名Top 50),阿里云博客专家、51CTO博客专家、华为云享专家 1、题目 编写函数f…

泉州模板开发建站不允许网站建设协议

大背景介绍 生信分析,凡事先看论文,有了论文就有了参考,后续分析就有底了,直接上硬菜开干: PCycDB: a comprehensive and accurate database for fast analysis of phosphorus cycling genes - PubMed 数据库及部分分析代码github库: GitHub - ZengJiaxiong/Phospho…

网站开发 附加协议怎么做网站 白

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼我装的ubt20&#xff0c;intel显卡已经GVT-t直通给群晖虚拟机&#xff0c;再映射给EMBY的docker了&#xff0c;权限什么都给了&#xff0c;命令测试都正常一播放就只会选择软解&#xff0c;CPU100%&#xff0c;不知道怎么回事rootd…

青岛网站seo价格哪些网站可以做移动端模板

由于单位的服务器均使用的是内网&#xff0c;而安装一些软件如Git&#xff0c;需要很多的依赖包&#xff0c;使用yum安装相对简单&#xff0c;由于不能联网故配置本地yum源配置。 1.首先将需要rpm库添加到系统中&#xff1a; 1).虚拟机中安装的linux操作系统:则只需将安装包ISO…

新手怎么自学ps百度seo公司报价

一、何为机器学习(Mechine Learning)&#xff1f; 答&#xff1a;利用已有数据(经验)&#xff0c;来训练某种模型&#xff0c;利用此模型来预测未来。机器学习是人工智能的核心Mechine Learning。 例如&#xff1a;你和狗蛋儿7点在老槐树下集合&#xff0c;如何一块约去开黑&a…

网站备案需要当面核验哪些信息答题做任务网站

预备知识 漏洞描述 OpenSSH8.3p1及之前版本中scp的scp.c文件存在操作系统命令注入漏洞。该漏洞即使在禁用ssh登录的情况下,但是允许使用scp传文件,而且远程服务器允许使用反引号(`)。攻击者可利用scp复制文件到远程服务器时,执行带有payload的scp命令,从而在后续利用中ge…

怎么做网站模板免费咨询电话

人人都想提高自己健康长寿的机率。下面的十个秘诀中&#xff0c;哪怕只选择一个&#xff0c;然后坚持实施&#xff0c;若干年后你会发现已经受益无穷。 1、喝茶 喝茶&#xff0c;特别是喝绿茶&#xff0c;其中的抗氧化剂可以抵挡有害物质对你身体的伤害。喝茶被证明可以减压…

惠安网站建设报价wordpress 压缩下载

有很多网友在问&#xff1a;TPlink路由器端口映射怎么设置&#xff1f;因为不懂端口映射的原理&#xff0c;所以无从下手&#xff0c;下面小编就给大家分享TPlink云路由器界面端口映射设置方法&#xff0c;帮助大家快速入门TP路由器端口映射设置方法。 1.登录路由器管理界面&a…

网站建设怎么让网站收录怎么做签到网站

RecyclerView 是 Android 官方推荐的用于展示大量数据列表的控件&#xff0c;具有高度的可定制性和灵活性。我们可以通过自定义 LayoutManager、ItemDecoration、ItemAnimator 等来实现不同的布局和动画效果&#xff0c;满足各种需求。同时&#xff0c;RecyclerView 支持局部刷…

网站建设怎么做更好wordpress 舆情管理

【dogkeji-科技犬】各位网友周末好&#xff0c;又到了2020年第十九周的PC、笔电、数码周边新品发布汇总时刻&#xff08;2020年5月4日至2020年5月9日&#xff09;&#xff0c;那么本周有那些PC、笔电、数码周边新品发布呢&#xff1f;通过科技犬的汇总我们来一起回顾一下吧。AM…