日期:2023-04-22 06:32:44 来源:程序员客栈
背景一种3D截图方案
参考 TRUE SPACE with Cocos 技术分享[1]中的动态生成海报的介绍,以及作者的支持。实现一个长按保存分享截图的方案。
效果在微信浏览器中预览效果如下
(资料图)
原作者讲的非常清楚,只需要按照以下步骤实现即可。
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年版
点击“阅读原文”查看精选导航
“点赞“ ”在看”鼓励一下▼
标签:
上一篇: 甘肃省临泽县市场监管局“监检结合”,护航人民群众 “舌尖上的安全”
下一篇: 最后一页
截图!长按保存分享!Cocos Creator
甘肃省临泽县市场监管局“监检结合”,护航人民群众 “舌尖上的安全”
股票行情快报:ST大洲(000571)4月21日主力资金净卖出141.45万元|全球视点
热门:20多万的“电动小帕美”来了,还要什么毛豆3?
即时:30秒|华为实现自主可控的MetaERP研发,任正非感谢合作伙伴
世界焦点!苏州有几个火车站分别位置_苏州有几个火车站
当前看点!奥飞数据(300738):4月21日北向资金增持174.12万股
今日精选:2023重庆涪陵区公务员考试笔试、面试和总成绩(4月16日)
当前速读:百度与用友网络签署战略合作 用友BIP全面接入文心一言
全球视点!斯特凡纳·弗雷斯_关于斯特凡纳·弗雷斯简介
推特开始清理遗留认证用户 改用“蓝勾勾”付费订阅制度
信阳市人社局召开一季度营商环境考核工作部署会
再陷调整!港股互联网跌跌不休,何时重振旗鼓?基金经理深度研判 要闻
矫枉
全球首台可变径斜井掘进机长沙下线-天天快资讯
全球观焦点:今年一季度义乌国际商贸城总成交额518.8亿元同比增长5.89%
关注:中国恒大:预计无法于4月30日前披露2022年度审计报告及2022年公司债券年度报告
题材杀跌 阶段风险将切换_天天最资讯
今日播报!漫漫人生路的意思_漫漫人生路是什么意思
cad导入不进su_cad导入su找不到
沙特阿美:首批获认证的低碳氨由沙特运往日本,将用于清洁发电 消息
闪贷3个月没还会上征信系统吗
每日消息!科创板首批退市企业揭晓!上交所对*ST紫晶、*ST泽达启动重大违法强制退市流程
环球最资讯丨特事特办马上就办_特事特办
反t怎么做_反tp补丁_世界微头条