背景一种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年版
点击“阅读原文”查看精选导航
“点赞“ ”在看”鼓励一下▼
从燃油车时代到新能源时代,整个车市都经历着转型的阵痛,如今的价格战就是一个很典型的现象,面对价格大乱斗,可以说绝大多数的车企都采用
近些年,随着自主品牌纷纷聚焦发力SUV,更多高品质、智能化的SUV逐步推向市场,也使得整个SUV市场逐渐内卷化,许多实力相近的产品,已经展
每当我们谈到性能车、JDM等话题时,似乎总是绕不过去一个名字:思域。15万左右的售价,7秒多就能够破百的动力表现,思域被冠以神车头衔,成
2022年8月15日,哈弗新能源技术媒体沟通会在北京举行。哈弗品牌CEO李晓锐、CTO吕文斌,与多位资深车圈媒体大咖分享了哈弗品牌2022年上半年
本不想躺平周末,浪费这难得的大好时光,但如何做,才能让自己的周末生活更有趣、过得更有意义呢?不如把自己交给哈弗H6S吧!出色性能+极致驾
油价起伏不定,环保意识逐步提高,今天的汽车消费者在选车时,对产品的经济、节能方面往往会有更多的苛求。正是因此,我国的汽车产业也在逐
导语:哈弗品牌狗品类家族迎来新成员哈弗酷狗的上市,凭借独特的敢性力量美学设计风格、强大的轻越野四驱能力与专业调校的音响系统收获了年
每个男人心中都有一个越野梦,但大多碍于账户余额迟迟没有实现。上个月,无意间看到了一场新车上市直播,哈弗大狗追猎版在库布齐沙漠的精彩
如果说工作是为了生存,那么周末存在的意义,便是让我们不负生活。熬过忙碌的五天工作日,周末怎能轻易躺平?顺从自己那颗躁动的心,来一场
年轻人想要一款什么样的SUV?对于这个问题,每个人心中其实都有着不同看法,或更在意外观,或更看重性能,或更注重配置等等。那么,有没有一
X 关闭
X 关闭