當前位置:主頁 > 要聞 > 正文
    截圖!長按保存分享!Cocos Creator-當前頭條
    來源:程序員客棧作者:洞察網2023-04-12 06:50:55

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

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

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

    [責任編輯:linlin]

    標簽:

    評論排行
    熱門話題
    最近更新
    国产亚洲精品成人AA片新蒲金| 中文字幕乱码亚洲精品一区 | 国产av无码专区亚洲av毛片搜| 亚洲永久在线观看| 亚洲伊人久久大香线蕉苏妲己| 国产AV无码专区亚洲A∨毛片| 国产gv天堂亚洲国产gv刚刚碰| 国产成人亚洲精品播放器下载| 亚洲欧洲无码一区二区三区| 国产成人亚洲综合网站不卡| 波多野结衣亚洲一级| 亚洲丰满熟女一区二区v| 亚洲欧洲日产专区| 亚洲最新黄色网址| 亚洲国产成人va在线观看网址| 亚洲综合激情视频| 亚洲国产成人久久| 亚洲男人天堂2018av| 亚洲性无码一区二区三区| 亚洲人成色在线观看| 亚洲国产精品成人AV在线| 亚洲国产欧美国产综合一区| 亚洲精品无码中文久久字幕| 国产亚洲精品影视在线| 亚洲精品午夜国产va久久| 亚洲字幕AV一区二区三区四区| 在线观看亚洲AV日韩AV| 亚洲精品乱码久久久久蜜桃| 亚洲日韩在线中文字幕综合| 国产精品亚洲专区一区| 亚洲日韩人妻第一页| 亚洲伊人久久大香线蕉综合图片| 在线a亚洲v天堂网2019无码| 亚洲色欲久久久综合网东京热| 亚洲国产精品无码久久SM| 久久亚洲精精品中文字幕| 亚洲免费人成视频观看| 国产精品亚洲一区二区麻豆| 国产亚洲欧美在线观看| 亚洲精品国产自在久久| 亚洲中文久久精品无码ww16|