背景一种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年版
点击“阅读原文”查看精选导航
“点赞“ ”在看”鼓励一下▼
上一篇:200g鸭绒和160g鹅绒?
下一篇:最后一页
今天来聊聊关于一周年纪念日祝福语有哪些内容,一周年纪念日祝福语有哪些的文章,现在就为大家来简单介绍下一周年纪念日祝福语有
编者按:作为湖南首家国家级经开区,31年来,长沙经开区的发展就是一部波澜壮阔的创业史,近两万家企业如雨后春笋般破土而出,
一、名记火箭很可能聘请沃格尔任主帅直播吧4月16日讯今天,名记Woj在节目中谈到了火箭的选帅情况。他说:“沃格尔本周接
很多人对自助餐饮料柜每瓶都是山寨货具体是什么情况比较关心,现在让我们一起来瞧瞧具体是什么情况吧!1、西安一知名品牌实体店
1、东北师范大学有网校,主要针对在职,成人。2、函授等。以上就是【东北师大附中网校怎么样,东北师大附中网校】相关内容。
如果保险交了几年想要退保的话,大家去退就可以了。 任何保险只要在保障期内,不管是几年之后,都可以申请退保。能否退保和交了多少年的保险
在北京时间今天凌晨进行的法甲第31轮比赛中,梅西取得进球,帮助巴黎主场3比1击败朗斯。据ESPN统计,梅西职业生涯至今已经打进805球,追平比坎
其次陵南也没有跟山王对抗的资本,陵南内线如果是甘愿当蓝领的鱼住那么近况会比赤木一开始好一点,仙道遇到泽北可以说是流川枫翻版,你说可以
大家好,这里是水幕这期是三国杀的一将之魂的制图介绍。一将之魂是集结了一将成名和原创之魂的一个大合集,据官方介绍,一共有70个将(曹彰进
Redis入门1 初始Redis1 1认识NoSQL||SQL(关系型数据库)|NoSQL(非关系型数据库)||||||数据结构|结构化(Structured)|非
X 关闭
上海推进三大先导产业规模实现倍增 打响“上海制造”品牌
深圳机场开通今年第5条国际货运航线 为深圳企业外贸出口提供新支撑
湖南公布90个建筑施工质量管理不合格工地名单
公众如何防范奥密克戎变异株?疾控专家回应
河南中招体育考试4月1日启动 计入中招成绩总分
婴幼儿疫苗最近暂停接种?郑州市疫情防控相关部门回应
X 关闭