截圖!長按保存分享!Cocos Creator

2023-04-29 22:34:38來源:程序員客棧

一種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年版

點擊“閱讀原文”查看精選導航

“點贊“ ”在看”鼓勵一下▼

關鍵詞:

責任編輯:孫知兵

免責聲明:本文僅代表作者個人觀點,與太平洋財富網無關。其原創性以及文中陳述文字和內容未經本站證實,對本文以及其中全部或者部分內容、文字的真實性、完整性、及時性本站不作任何保證或承諾,請讀者僅作參考,并請自行核實相關內容。
如有問題,請聯系我們!

關于我們 - 聯系方式 - 版權聲明 - 招聘信息 - 友鏈交換 - 網站統計
 

太平洋財富主辦 版權所有:太平洋財富網

?中國互聯網違法和不良信息舉報中心中國互聯網違法和不良信息舉報中心

Copyright© 2012-2020 太平洋財富網(www.8899ip.com) All rights reserved.

未經過本站允許 請勿將本站內容傳播或復制 業務QQ:3 31 986 683

 

主站蜘蛛池模板: 国产成人精品免费视频大全可播放的 | 成人精品一区二区户外勾搭野战 | 全彩成人18h漫画在线| 国产成人高清在线播放| 久久精品成人一区二区三区| 91欧美激情一区二区三区成人| 成人在线视频免费| 亚洲色成人网一二三区| 成人欧美日韩一区二区三区| 亚洲欧洲精品成人久久曰| 成人午夜在线视频| 麻豆国产成人AV在线 | 88aa四虎影成人精品| 国产成人精品美女在线| 欧美成人午夜做受视频| 国产成人免费一区二区三区| 欧美成人国产精品高潮| 国产成人亚洲综合一区| 欧美成人精品第一区| 亚洲国产成人久久一区www| 国产成人av乱码在线观看| 成人国产一区二区三区| 久久久噜噜噜www成人网| 国产成人无码av片在线观看不卡| 成人在线视频一区| 日韩国产成人精品视频| 久久成人国产精品一区二区| 国产成人无码精品一区在线观看| 国产精品成人不卡在线观看| 成人午夜精品无码区久久| 欧美亚洲国产成人综合在线 | 亚洲人成人无码网www国产| 国产成人精品福利网站在线观看| 欧美成人免费在线观看| 999影院成人在线影院| 黑人粗长大战亚洲女2021国产精品成人免费视频 | 四虎永久成人免费影院域名| 国产精品成人无码久久久| 国产成人精品免费视频软件| 国产成人精品久久综合| 亚洲欧美一区二区成人片|