截图!长按保存分享!Cocos Creator
背景一种3D截图方案
参考 TRUE SPACE with Cocos 技术分享[1]中的动态生成海报的介绍,以及作者的支持。实现一个长按保存分享截图的方案。
(资料图)
在微信浏览器中预览效果如下
环境Cocos Creator 3.7.1Web 浏览器原理原作者讲的非常清楚,只需要按照以下步骤实现即可。
3D相机生成一个RT 赋予给2D精灵摆上一些二维码等UIUI相机再生成一张RT读取RT中的数据,传给 canvascanvas 生成图片数据传给 Image适配Image对象大小位置视频录了一段操作视频[2]供大家参考。
代码这段代码的截图功能是按照高度适配的方式写的,如有其他需求,可自行修改相关逻辑。仅供大家参考学习。
import{_decorator,Component,Node,Camera,RenderTexture,view,UITransform,log,game,screen,NodeEventType}from"cc";const{ccclass,property}=_decorator;@ccclass("CaptureImage")exportclassCaptureImageextendsComponent{@property(Camera)copyCamera:Camera=null!;@property(Node)targetNode:Node=null!;@property(Node)captureBtn:Node=null!;@property(Node)closeBtn:Node=null!;rt:RenderTextureprivate_image:HTMLImageElement_canvas:HTMLCanvasElement=null!;_buffer:ArrayBufferView=null!;start(){log("欢迎关注微信公众号【白玉无冰】https://mp.weixin.qq.com/s/4WwCjWBtZNnONh8hZ7JVDA")this.rt=newRenderTexture();this.rt.reset({width:view.getVisibleSize().width,height:view.getVisibleSize().height,})this.copyCamera.targetTexture=this.rt;this.captureBtn.active=true;this.closeBtn.active=false;this.captureBtn.on(NodeEventType.TOUCH_END,this.copyRenderTex,this)this.closeBtn.on(NodeEventType.TOUCH_END,this.clearCapture,this)}privatecopyRenderTex(){constwidth=this.targetNode.getComponent(UITransform).width;constheight=this.targetNode.getComponent(UITransform).height;constanchorPoint=this.targetNode.getComponent(UITransform).anchorPoint;constworldPos=this.targetNode.getWorldPosition();this._buffer=this.rt.readPixels(Math.round(worldPos.x-width*anchorPoint.x),Math.round(worldPos.y-height*anchorPoint.y),width,height);if(!this._canvas){this._canvas=document.createElement("canvas");this._canvas.width=width;this._canvas.height=height;}else{letctx=this._canvas.getContext("2d");ctx.clearRect(0,0,this._canvas.width,this._canvas.height);}letctx=this._canvas.getContext("2d")!;letrowBytes=width*4;for(letrow=0;row其他 最近写文偏笔记的形式,主要是记录一下代码,下次要用的时候再翻出来。希望对大家有所帮助。
参考资料[1]
TRUE SPACE with Cocos 技术分享:https://forum.cocos.org/t/topic/146459
[2]视频:https://www.bilibili.com/video/BV1w84y1N7XQ
往期精彩:
3DUI Cocos Creator
三渲二 Cocos Creator
零代码实现面片效果(UV滚动,帧动画) Cocos Creator
游戏开发资料合集,2022年版
点击“阅读原文”查看精选导航
“点赞“ ”在看”鼓励一下▼
关键词:
责任编辑:宋璟
-
白银短线突发急涨行情!白银日内交易分析:若突破首个目标 银价有望再飙升逾3%|全球速递
-
PPT | 退役风电机组回收利用与碳减排
-
优化营商环境 多听企业意见(经济时评)|当前观点
-
2023浙江金华市武义县各级机关单位考试录用公务员拟录用人员公示(二)
-
邹越演讲观后感200字(邹越演讲观后感)
-
力争零售总额突破2万亿元 湖南出台促消费政策最高补贴1000万元
-
天天报道:乘舟向天宫!中国空间站应用与发展阶段任务拉开序幕
-
《自然》发表首个人类泛基因组草图,更完整描绘遗传多样性-当前头条
-
天天快看点丨揭秘 发射前6小时“赶飞船”
-
卡西欧标准差_卡西欧计算器算标准差
-
华新水泥(06655.HK):5月10日南向资金增持10.84万股
-
当前头条:魏国秋_关于魏国秋简述
-
蒙蒂:今天掘金一直包夹布克和杜兰特 我们在进攻端没有足够产出-环球快看
-
环球快资讯:中超-巴顿远射破门王子铭救主明天染红 国安1-1十人天津
-
牛年古诗有哪些 关于牛年的古诗大全
-
世界热议:成都幼儿园线上报名人数太多可以换一个吗2023?
-
42647辆!比亚迪秦登顶4月轿车销量排行榜!-每日信息
-
经营活动产生的现金流量净额为负数怎么调整 经营活动产生的现金流量净额为负
-
文字技巧—隐藏的分隔符怎么删除
-
环球热点评!吴诚博士 吴诚真书画价格
-
什么是网络男神_什么是网络设备 全球实时
-
2023北京未来砚园共有产权房申购指南(时间+官网)-消息
-
世界滚动:天舟六号,今晚发射!
-
造价员和预算员的区别 请详细点(造价员和预算员的区别是什么)|前沿热点
-
全球焦点!晚间公布美国4月CPI数据 黄金高位盘整
-
热点!行业首个健康营养展NHNE(2023春)于青岛盛大开幕!
-
施时楷_关于施时楷介绍 天天微资讯
-
今日热搜:“码”上监管 惠企便民——石家庄市大力优化营商环境进行时之二
-
今年618视频号先卷为敬
-
世界微动态丨华宝新能董秘回复:目前,公司率先发布了免安装、中小型容量的移动式家庭储能产品,并实现了快速增长
-
今日视点:5月10日燃料电池板块涨幅达2%
-
天天速讯:2023年广西高考第二次征集志愿12月24日开始填报
-
世界今日报丨每天吃一盒蓝莓会发生什么?皮肤真的会变白?视力真的会变好?
-
世界热点评!青岛崂山区拟于5月30日出让1宗商住地 起价17.14亿元
-
用心用情保护传统村落文化遗产-环球快资讯