背景一種3D截圖方案
參考 TRUE SPACE with Cocos 技術(shù)分享[1]中的動(dòng)態(tài)生成海報(bào)的介紹,以及作者的支持。實(shí)現(xiàn)一個(gè)長(zhǎng)按保存分享截圖的方案。
(相關(guān)資料圖)
在微信瀏覽器中預(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]供大家參考。
代碼這段代碼的截圖功能是按照高度適配的方式寫(xiě)的,如有其他需求,可自行修改相關(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其他 最近寫(xiě)文偏筆記的形式,主要是記錄一下代碼,下次要用的時(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)畫(huà)) Cocos Creator
游戲開(kāi)發(fā)資料合集,2022年版
點(diǎn)擊“閱讀原文”查看精選導(dǎo)航
“點(diǎn)贊“ ”在看”鼓勵(lì)一下▼
關(guān)鍵詞:
參與評(píng)論
- 焦點(diǎn)熱議:截圖!長(zhǎng)按保存分享!Cocos Creator2023-04-05
- 【世界速看料】駢怎么讀_駢齒2023-04-05
- 環(huán)球即時(shí):@洛陽(yáng)小微企業(yè)、個(gè)體工商戶:所2023-04-05
- 今日視點(diǎn):“緬懷先烈、致敬英雄”靈龍小學(xué)2023-04-05
- 世界播報(bào):榆社縣氣象局發(fā)布大風(fēng)藍(lán)色預(yù)警【2023-04-05
- 海南全島封關(guān)意義重大2023-04-05
- 郵箱號(hào)碼怎么填寫(xiě)_郵箱號(hào)碼注冊(cè)2023-04-05
- 快看點(diǎn)丨火影忍者阿斯瑪在第幾集死的_火影2023-04-05
- 全球訊息:奧薩蘇納總比分2-1淘汰畢包,時(shí)2023-04-05
- 馬云推出的移動(dòng)房子是什么_移動(dòng)的房子有什2023-04-05
- 當(dāng)前快播:vero moda 女裝_veromoda新款女裝2023-04-05
- 全球熱資訊!周鴻祎離婚后,360高層朋友圈2023-04-04
- 焦點(diǎn)熱文:補(bǔ)心第一方,滋陰血、通陽(yáng)氣,心2023-04-04
- 機(jī)構(gòu):超28%美國(guó)智能手機(jī)用戶換機(jī)時(shí)會(huì)考慮2023-04-04
- 每日視訊:青春伴稅行!內(nèi)江開(kāi)展稅法宣傳進(jìn)2023-04-04
- 環(huán)球簡(jiǎn)訊:溫州醫(yī)博肛腸??漆t(yī)院 百姓好評(píng)2023-04-04
- 國(guó)四精品丨晉工JGM857M輪式裝載機(jī),高效舒2023-04-04
- 百事通!中國(guó)銀河給予亞鉀國(guó)際推薦評(píng)級(jí) 百2023-04-04
- 當(dāng)前焦點(diǎn)!社區(qū)治理|五社聯(lián)動(dòng)助力桂林社區(qū)培2023-04-04
- 今日觀點(diǎn)!橫浦村2023-04-04
- 環(huán)球精選!多牛科技現(xiàn)漲超3% 擬溢價(jià)約2.012023-04-04
- 每日動(dòng)態(tài)!2023年3月第5周武漢新房住宅成交32023-04-04
- 和訊個(gè)股快報(bào):2023年04月04日 新五豐(602023-04-04
- 資訊推薦:逾期收到12368信息是不是被起訴了2023-04-04
- 高智商2023-04-04
- 環(huán)球今亮點(diǎn)!銀河證券:醫(yī)療AI診斷先行 新2023-04-04
- 常州上榜!二線強(qiáng)市!2023-04-04
- 每日視點(diǎn)!特斯拉降價(jià)引發(fā)利潤(rùn)擔(dān)憂 市值蒸2023-04-04
- 全球今亮點(diǎn)!今年車險(xiǎn)送什么禮品2023-04-04
- 世界熱點(diǎn)評(píng)!庫(kù)布春站2023-04-04