背景一种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]中的动态生成海报的介绍,以及作者的支持。实现一...
海外网4月21日电根据法国生活条件研究及观察中心(Credoc)最新公布的一份研究报告,法国40岁至59岁中年...
今天,一起翻开书本,在读书的小天地“打个卡”,留下你的读书感悟吧。
日前,由中国科学技术协会主办的“科创中国”金融科技产业创新论坛暨(2022)第六届中国金融科技创新大...
当然,如果有这样的形容词适合Mopar机器,我们已经看过2020年的雪佛兰克尔维特(ChevroletCorvette
欢迎观看本篇文章,小勉来为大家解答以上问题。酱牛肉最正宗的做法,酱牛肉怎么做很多人还不知道,现在...
怀远县气象局更新大风蓝色预警【IV级 一般】
近日,浙江杭州,一位大爷到包子铺买了3个包子当他完成支付后,语音提示的到账金额惊呆了店主:十九万六...
1、白羊座女孩喜欢什么类型的男孩:冷面酷男 热情的白羊女在感情上追求独立,对于那些婆婆妈妈,死缠...
今天来聊聊关于上海股权托管交易中心官网下载,上海股权托管交易中心官网的文章,现在就为大家来简单介...
外媒Looper独家消息,新海诚在接受采访时表示,《铃芽之旅》差点成为一部女同性爱情片。
1、全称是《城镇污水处理厂污染物排放标准》GB18918-2002一级A及一级B标准。2、简单来说有回用要求的执行一级
1、征召模式就是“排位模式”排位分就必须打这个才能获取需要英雄等级30级匹配模式就是普通模式,匹配战...
中国山东网-感知山东4月22日讯(记者何普言通讯员王晓兰)近日,在山东单县绿禾庄园里,来自加纳的小伙左...
800家商铺,一起承诺完成这件事!
很多人对福岛核污染水排海或于7月实施具体是什么情况比较关心,现在让我们一起来瞧瞧具体是什么情况吧!...
林武出席军委国防动员部学习贯彻习近平新时代中国特色社会主义思想培训班活动介绍山东推动经济社会高质...
想做手账费时又花钱?教你5分钟完成手账设计,而且不花一分钱!成品图镇楼01我最喜欢的风格之中国风我开...
当自己受伤难过的时候何不如想一想那些快乐的事情,不再去想念、不再去记起,在难过伤心的时候,可以去...
哈兰德继续自己的进球脚步。4月20日凌晨,欧冠联赛剩余两个四强席位揭晓。在四分之一决赛次回合中,曼城...
1、悟空租车是脚印兄弟(北京)信息科技有限责任公司旗下品牌,是以移动互联网技术为依托,专注于B2P全...
拉莫斯加盟大巴黎,一大目标就是帮助球队夺得欧冠。在接受采访时,他也透露了自己的这个愿望。拉莫斯表...
【第一批带押过户的卖房人已经省钱了】带押过户业务早在2008年于上海已有先例,但直到2022年,带押过户...
现在内部号的流出,很多小伙伴不知道哪里可以申请游戏内部号,今天我来为大家解答,请听讲。现在有一些...
4月21日晚,造纸行业头部企业太阳纸业公告2022年年报,在造纸行业经历2008年全球金融危机以来“最困难一...
X 关闭
X 关闭