截图!长按保存分享!Cocos Creator_世界速讯

2023-04-22 10:17:44 | 来源:程序员客栈

一种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年版

点击“阅读原文”查看精选导航

“点赞“ ”在看”鼓励一下▼

上一篇 下一篇

相关新闻

截图!长按保存分享!Cocos Creator_世界速讯

【焦点热闻】总部企业认定向战略性新兴产业现代服务业倾斜

热水器保温一天24小时耗电多少_一天24小时多少分多少秒-天天简讯

人行消保局、海口中心支行到工行海南分行消保特色网点参观座谈-焦点热闻

直裰的意思 直裰 每日播报

佛山市低保申请条件-世界观速讯

华一股份过会:今年IPO过关第96家 国盛证券过首单_最新

专家解读美国星舰发射失败:系人类历史上最大的火箭,实现火星移民还有更多困难要攻克

西昌属于哪个省哪个市哪个区_西昌属于哪个省|快报

开封市祥符区兴隆乡:五色草种出乡村振兴多彩路|微头条

宝马 MINI 再回应冰淇淋事件,网友:史诗级拉跨公关

东市买骏马是哪首诗_东市买骏马-环球即时看

奥园集团回应收到上交所通报批评:正积极配合推进审计工作|今日热闻

2023U.I.M.F1摩托艇世界锦标赛|点亮全城地标,一起加速狂飙! 焦点讯息

当前信息:borderlands 2 game of the year_borderlands 2怎么设置中文

最新新闻

截图!长按保存分享!Cocos Creator_世界速讯

【焦点热闻】总部企业认定向战略性新兴产业现代服务业倾斜

热水器保温一天24小时耗电多少_一天24小时多少分多少秒-天天简讯

人行消保局、海口中心支行到工行海南分行消保特色网点参观座谈-焦点热闻

直裰的意思 直裰 每日播报

佛山市低保申请条件-世界观速讯

华一股份过会:今年IPO过关第96家 国盛证券过首单_最新

专家解读美国星舰发射失败:系人类历史上最大的火箭,实现火星移民还有更多困难要攻克

西昌属于哪个省哪个市哪个区_西昌属于哪个省|快报

开封市祥符区兴隆乡:五色草种出乡村振兴多彩路|微头条

宝马 MINI 再回应冰淇淋事件,网友:史诗级拉跨公关

东市买骏马是哪首诗_东市买骏马-环球即时看

奥园集团回应收到上交所通报批评:正积极配合推进审计工作|今日热闻

2023U.I.M.F1摩托艇世界锦标赛|点亮全城地标,一起加速狂飙! 焦点讯息

当前信息:borderlands 2 game of the year_borderlands 2怎么设置中文

豪掷400亿布局光伏,合盛硅业回应:公司具备一定成本优势

2022年江苏人均每日阅读时长85.35分钟|世界短讯

湖北黄冈“黑科技”亮相第二届中国(武汉)文旅博览会 实时

奔驰G级推出特别版车型 为纪念50万辆下线_快播报

潮州市松发陶瓷有限公司_关于潮州市松发陶瓷有限公司介绍-当前滚动

美元/瑞郎行情综述(2023年4月21日)

速递!精准聚焦用户需求 提升供水服务实效 信阳市供水公司志愿服务进社区活动

香山股份2022年归母净利润同比增长72% 新能源产品销售量大幅提升 世界快资讯

焦点!福能东方股东户数减少204户,户均持股9.77万元

疯狂农场2攻略_有什么玩的步骤_世界新消息

imf是什么意思啊数学(imf是什么意思) 世界今热点

美国男子遭警察射杀:全身57处枪伤 没有携带武器迹象

中国篮球公开赛大区赛开打

中国建筑兴业(00830)一季度经营溢利约为3.3亿港元 同比增长35% 焦点观察

环球焦点!“淄博烧烤”秘籍传入高校食堂?靠这些“细节”做到原汁原味……