截图!长按保存分享!Cocos Creator-最资讯
一种3D截图方案背景参考TRUESPACEwithCocos技术分享[1]中的动态生成海报的介绍,以及作者的支持。实现一个长按保存分享截图的方案。效果
背景一种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年版
点击“阅读原文”查看精选导航
“点赞“ ”在看”鼓励一下▼
关键词:
一种3D截图方案背景参考TRUESPACEwithCocos技术分享[1]中的动态生成海报的介绍,以及作者的支持。实现一个长按保存分享截图的方案。效果
今天来聊聊关于excel表格里数字前面有个逗号,excel表格数字前面有逗号怎么去掉的文章,现在就为大家来简单介绍下ex
海南省首家中英文双语金融教育基地揭牌仪式暨金融知识进校园宣传活动成功举行
今年一季度义乌国际商贸城总成交额518 8亿元,同比增长5 89%
4月22日,2023U I M F1摩托艇世界锦标赛中国郑州大奖赛志愿者培训暨开班仪式,在郑州大学体育学院举行。来自郑大体院、华北水利水电大学两所高
你们好,最近小活发现有诸多的小伙伴们对于美团差评回复话术模板,美团差评回复这个问题都颇为感兴趣的,今天小活为大家梳理了下
近年来,折叠屏手机的认可度越来越高,由于工艺技术的提升,许多折叠屏的短板与通病被克服,不少用户购机时会考虑购买折叠屏手机作为主力机使
1、北京首都国际机场PEK北京上海浦东国际机场PVG上海广州白云国际机场CAN广东广州上海虹桥国际机场
做完核酸在手上盖章,防疫不能冒犯居民尊严■视点不管是在何种场景之下,防疫举措的制定者和执行人员都必须保持对个体的基本尊
1、打开工资税计算表,输入累计工资收入。2、输入每个项目的累计扣减额。3、要计算累计应纳税所得额,请输入以下公式:4、=
睡醒后仍然疲惫,甚至出现嗜睡的情况,就要看看晚上睡觉是否打鼾,长期打鼾首先影响的就是睡眠质量,久之还会影响血压、心律。如
近日华利集团披露,截至2023年4月10日公司股东户数为1 2万户,较3月31日增加76 0户,增幅为0 64%。户均持股数量由上期的9 79万股减少至9 72万
今天小编肥嘟来为大家解答以上的问题。6s标准化管理的意义,6s标准化管理相信很多小伙伴还不知道,现在让我们一起来看看吧!1、“6S”现场管理
新甘肃客户端4月21日讯(新甘肃·每日甘肃网记者郭秀睿)今天,记者从人民银行兰州中心支行召开的2023年一季度甘肃省金融数据及金融助力“拼经
1、我们先在手机上下载安装好中国工商银行手机银行的APP,然后我们点击中国工商银行。2、之后我们点击左上角的登录。3、登录界面是无法截图的
宝宝树回应被举报造假:公司目前经营管理一切正常,3月工资已发,宝宝树,一切正常,徐翀,复星,母婴,财务官
伦纳德因右膝扭伤将缺席对阵太阳的首轮G3,膝伤,快船队,美国篮球,科怀·伦纳德
“教练,我想打篮球!”动画电影《灌篮高手》上映啦!我的篮球梦再一次热血沸腾!今天就去打一场篮球~~“爷青回”!篮球作为一
Socket编程是一种在计算机网络上实现通信的标准方式,该编程模型被广泛应用于网络编程中。本文将为您介绍Socket编程的基础知识、常见概念和使
1、810语数英共450政治、物理、化学共300体育60。