今日精选:截图!长按保存分享!Cocos Creator
一种3D截图方案背景参考TRUESPACEwithCocos技术分享[1]中的动态生成海报的介绍,以及作者的支持。实现一个
程序员客栈 2023-04-23 17:22:00
背景一种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]中的动态生成海报的介绍,以及作者的支持。实现一个
1、伪装学渣作者:木瓜黄文案:分班后,两位风靡校园的“问题少年”不止分进一个班还成为同桌。2、明明是学
小米上亿资产遭冻结申诉被印度驳回回应称等待书面命令
三国演义第一回读后感50字,三国演义第一回读后感这个很多人还不知道,现在让我们一起来看看吧!1、读后感:
章源钨业2022年实现营业收入32 03亿元,归母净利润2 03亿元,其中营收是第一季度较高,第四季度较低。
烧烤出圈后,淄博应考的破与立
乐居财经王敏4月19日,浙江泛源科技股份有限公司(以下简称“泛源科技”)披露第一轮审核问询回复,拟登陆
河南新惠建设投资9 87亿元私募获上交所受理
哈姆:任何对詹姆斯表达质疑的人都会让我们更加努力尤其是狄龙,狄龙,湖人,美国篮球,米娅·哈姆,勒布朗詹姆
软件大小: 160 kb 软件类型 理财购物 软件平台: Android 软件等级 ★★★★★
大家都知道在耕耘版本中,加入了很多优化内容,例如删除时间不足24小时的道具会有标记提升,装备打造时,可
网传西安一大学生连续三年每晚关水阀,学校因此获节水型高校?最新回应
据省图书馆党委书记、馆长孔德超介绍,在4月23日—29日公共图书馆服务宣传周期间,将开展一系列群众喜闻乐
1、步骤1 2、准备所需的材料3、步骤2 4、将200克水倒入容器中。5、步骤3 6、将60克藻酸盐和20克氯化钠混合,
环绕音,关于环绕音介绍这个很多人还不知道,我们一起来看看!1、环绕音是指通过放置音源于不同的位置,通过