2023-04-21 15:21:30來(lái)源:程序員客棧
背景一種3D截圖方案
(資料圖片僅供參考)
參考 TRUE SPACE with Cocos 技術(shù)分享[1]中的動(dòng)態(tài)生成海報(bào)的介紹,以及作者的支持。實(shí)現(xiàn)一個(gè)長(zhǎng)按保存分享截圖的方案。
效果在微信瀏覽器中預(yù)覽效果如下
環(huán)境Cocos Creator 3.7.1Web 瀏覽器原理原作者講的非常清楚,只需要按照以下步驟實(shí)現(xiàn)即可。
3D相機(jī)生成一個(gè)RT 賦予給2D精靈擺上一些二維碼等UIUI相機(jī)再生成一張RT讀取RT中的數(shù)據(jù),傳給 canvascanvas 生成圖片數(shù)據(jù)傳給 Image適配Image對(duì)象大小位置視頻錄了一段操作視頻[2]供大家參考。
代碼這段代碼的截圖功能是按照高度適配的方式寫的,如有其他需求,可自行修改相關(guān)邏輯。僅供大家參考學(xué)習(xí)。
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("歡迎關(guān)注微信公眾號(hào)【白玉無(wú)冰】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其他 最近寫文偏筆記的形式,主要是記錄一下代碼,下次要用的時(shí)候再翻出來(lái)。希望對(duì)大家有所幫助。
參考資料[1]
TRUE SPACE with Cocos 技術(shù)分享:https://forum.cocos.org/t/topic/146459
[2]視頻:https://www.bilibili.com/video/BV1w84y1N7XQ
往期精彩:
3DUI Cocos Creator
三渲二 Cocos Creator
零代碼實(shí)現(xiàn)面片效果(UV滾動(dòng),幀動(dòng)畫) Cocos Creator
游戲開發(fā)資料合集,2022年版
點(diǎn)擊“閱讀原文”查看精選導(dǎo)航
“點(diǎn)贊“ ”在看”鼓勵(lì)一下▼
責(zé)任編輯:
標(biāo)簽:
一種3D截圖方案背景參考TRUESPACEwithCocos技術(shù)分享[1]中的動(dòng)態(tài)生成海報(bào)的介紹,以及作者的支持。實(shí)現(xiàn)一個(gè)
長(zhǎng)三角區(qū)域重點(diǎn)城市知識(shí)產(chǎn)權(quán)發(fā)展報(bào)告出爐蘇州、南京綜合實(shí)力位列前五中國(guó)江蘇網(wǎng)訊(記者蔡姝雯程曉琳)4月2
萬(wàn)里奔赴,風(fēng)云際會(huì)。在全球往來(lái)復(fù)蘇之際,一場(chǎng)國(guó)際盛會(huì)將在浙江啟幕。作為唯一聚焦中國(guó)-中東歐國(guó)家合作的
菌落總數(shù)超標(biāo)50倍!“網(wǎng)紅”竹筒奶茶店被責(zé)令關(guān)停整改
1、贊美長(zhǎng)江的詩(shī)句無(wú)邊落木蕭蕭下,不盡長(zhǎng)江滾滾來(lái)杜甫《登高》孤帆遠(yuǎn)影碧空盡,惟見長(zhǎng)江天際流