亚洲精品久久久久久久久久久,亚洲国产精品一区二区制服,亚洲精品午夜精品,国产成人精品综合在线观看,最近2019中文字幕一页二页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

談?wù)刢ocos2d-x多線程渲染

Dbwd_Imgtec ? 來(lái)源:未知 ? 作者:胡薇 ? 2018-05-23 10:40 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

可行性:

游戲循環(huán)主要包括這幾個(gè)部分:

硬件事件,主要就是指觸屏事件,按鍵事件和鼠標(biāo)事件;

游戲事件,主要指定時(shí)器事件和預(yù)定義事件,比如schedule;

游戲邏輯,對(duì)于胖腳本端來(lái)說(shuō),這個(gè)就指的腳本邏輯;

渲染數(shù)據(jù)的生成,在引擎里面就是指node的visit,這里計(jì)算生成所有即將發(fā)往OpenGL的數(shù)據(jù),包括頂點(diǎn)紋理坐標(biāo)等attribute數(shù)據(jù),變換矩陣紋理等uniform數(shù)據(jù),混合模式等渲染狀態(tài);

通過(guò)OpenGL接口把所有數(shù)據(jù)發(fā)往OpenGL。

這幾個(gè)步驟里面,只有第五個(gè)步驟需要涉及到OpenGL操作,而前面四個(gè)步驟都是為第五個(gè)步驟做準(zhǔn)備,而第五個(gè)步驟不用或者很少需要反饋數(shù)據(jù)給前面四個(gè)步驟。這是一個(gè)典型的生產(chǎn)者消費(fèi)者模式,在很低線程同步開銷的情況下課采用多線程處理。

必要性:

處理游戲邏輯(包括前四個(gè)步驟)承擔(dān)了太多cpu運(yùn)算,而發(fā)數(shù)據(jù)到OpenGL也相當(dāng)耗時(shí),尤其涉及到多次的渲染狀態(tài)切換。在多核cpu上面把二者分開可以提高并行性,進(jìn)而提高游戲幀率。

一些方案:

cocos2d-x3.0之后有一個(gè)很大的轉(zhuǎn)變就是不是在visit里面渲染,而是在visit里面生成渲染命令,并把命令發(fā)往render類緩存,等待某個(gè)時(shí)機(jī)處理這些命令,即渲染。

這是一個(gè)典型的命令模式,只要保證這些command的執(zhí)行處理的數(shù)據(jù)和主線程(游戲邏輯的執(zhí)行線程)不一樣或者通過(guò)加鎖做好和主線程的數(shù)據(jù)互斥,就可以保證線程安全。大多數(shù)數(shù)據(jù)我們都可以在visit(其實(shí)是draw)里面生成一份拷貝,而對(duì)于較少個(gè)數(shù)但是每個(gè)都包含大量頂點(diǎn)數(shù)據(jù)的對(duì)象,我們可以通過(guò)加鎖做好互斥,比如粒子系統(tǒng)。較少的線程互斥操作也不會(huì)造成太大線程通信開銷。

游戲主循環(huán)也是先執(zhí)行游戲邏輯相關(guān)的四個(gè)步驟,然后通過(guò)條件變量告知渲染線程數(shù)據(jù)已經(jīng)準(zhǔn)備好。我們也可以使用雙緩存系統(tǒng),即創(chuàng)建兩個(gè)渲染命令緩存,在渲染線程使用一個(gè)命令緩存進(jìn)行渲染的時(shí)候,主線程邏輯可以把渲染命令發(fā)往另一個(gè)緩存。

如果主線程邏輯確實(shí)需要OpenGL處理才能得到的一些數(shù)據(jù),我們也可以采用一些較為低效的折中方案。主線程通過(guò)類似于schedule的方式把命令發(fā)往渲染線程,然后等待,渲染線程維持一個(gè)這樣的命令隊(duì)列,每個(gè)周期優(yōu)先處理這個(gè)隊(duì)列,處理完成后通知主線程。這種做法不易多用。

說(shuō)個(gè)例子,同步創(chuàng)建紋理并生成sprite的操作,這個(gè)生成紋理的部分需要放到渲染線程,這個(gè)就可以采用這種方案。而事實(shí)上游戲邏輯根本不需要關(guān)心這個(gè)紋理到底長(zhǎng)什么樣,主線程可以不用等到渲染線程處理完成這個(gè)紋理再繼續(xù)運(yùn)行,渲染線程再處理完成這個(gè)紋理后,通過(guò)schedule告知主線程,主線程更新這個(gè)texture2d對(duì)象的紋理ID即可,大大提高效率。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 多線程
    +關(guān)注

    關(guān)注

    0

    文章

    279

    瀏覽量

    20854
  • 渲染
    +關(guān)注

    關(guān)注

    0

    文章

    78

    瀏覽量

    11321

原文標(biāo)題:cocos2d-x多線程渲染的一些探討

文章出處:【微信號(hào):Imgtec,微信公眾號(hào):Imagination Tech】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    rt-thread studio 如何進(jìn)行多線程編譯?

    ,使用的是5800h+32g內(nèi)存+sn550 ssd,開啟16線程編譯時(shí)cpu的占用率也只能到30%,編譯完整個(gè)工程需要3分鐘 感覺多線程編譯設(shè)置沒有生效,有辦法提高編譯速度嗎 rtthread studio版本是 2.2.9
    發(fā)表于 10-11 09:16

    tcpip線程被mu0鎖住導(dǎo)致網(wǎng)絡(luò)線程無(wú)法使用怎么解決?

    = %d\",ch); if(ch == 0x01) { mem_monitor2(NULL); list_thread(); list_sem(); list_msgqueue
    發(fā)表于 09-29 06:41

    【HZ-T536開發(fā)板免費(fèi)體驗(yàn)】—— linux創(chuàng)建線程

    自己的私有資源。 在linux系統(tǒng)中,線程狀態(tài)通常反映了當(dāng)前線程的當(dāng)前活動(dòng)和執(zhí)行階段。 主要分為: 1。運(yùn)行轉(zhuǎn)態(tài) 2。阻塞轉(zhuǎn)態(tài) 3。終止?fàn)顟B(tài) 如何區(qū)分單線程
    發(fā)表于 09-01 21:31

    【RA4E2開發(fā)板評(píng)測(cè)】LED1及LED2輪流點(diǎn)亮并同時(shí)亮8秒,體驗(yàn)FreeRTOS多線程

    我們要多線程操作時(shí),就需要用到RTOS(Real-Time Operating System)。FreeRTOS實(shí)時(shí)操作系統(tǒng)開發(fā)里面使用到vTaskDelay函數(shù),它是對(duì)CPU的時(shí)分復(fù)用,系統(tǒng)將這個(gè)
    發(fā)表于 08-24 17:24

    通道渲染:釋放渲染的全部潛能!通道渲染的作用、類型、技巧

    在3D圖形創(chuàng)作中,渲染通道(RenderPasses)是一項(xiàng)至關(guān)重要的技術(shù),它通過(guò)將復(fù)雜的渲染圖像拆分為多個(gè)圖層,如陰影、光照、法線等,使藝術(shù)家能夠在后期制作中更精準(zhǔn)地控制和調(diào)整畫面。我們常常驚嘆于
    的頭像 發(fā)表于 07-15 14:22 ?347次閱讀
    通道<b class='flag-5'>渲染</b>:釋放<b class='flag-5'>渲染</b>的全部潛能!通道<b class='flag-5'>渲染</b>的作用、類型、技巧

    多線程的安全注意事項(xiàng)

    多線程安全是指多個(gè)線程同時(shí)訪問或修改共享資源時(shí),能夠保證程序的正確性和可靠性。 開發(fā)者選擇TaskPool或Worker進(jìn)行多線程開發(fā)時(shí),在TaskPool和Worker的工作線程中導(dǎo)
    發(fā)表于 06-20 07:49

    工控一體機(jī)多線程任務(wù)調(diào)度優(yōu)化:聚徽分享破解工業(yè)復(fù)雜流程高效協(xié)同密碼

    在當(dāng)今工業(yè) 4.0 的浪潮下,工業(yè)生產(chǎn)正朝著高度自動(dòng)化、智能化的方向大步邁進(jìn)。生產(chǎn)流程日益復(fù)雜,眾多任務(wù)需要同時(shí)、高效地協(xié)同執(zhí)行,這對(duì)工業(yè)控制系統(tǒng)的核心 —— 工控一體機(jī)提出了前所未有的挑戰(zhàn)。多線程
    的頭像 發(fā)表于 05-28 14:06 ?410次閱讀

    摩爾線程MTT X300顯卡全新性能升級(jí)

    摩爾線程近日發(fā)布的Linux驅(qū)動(dòng)程序v3.0.0,為MTT X300專業(yè)顯卡帶來(lái)全面的性能提升。此次升級(jí)通過(guò)軟硬件深度協(xié)同優(yōu)化,顯著提升了GPU渲染性能,使MTT X300在數(shù)字孿生、
    的頭像 發(fā)表于 05-27 18:03 ?1217次閱讀

    CPU渲染、GPU渲染、XPU渲染詳細(xì)對(duì)比:哪個(gè)渲染最快,哪個(gè)效果最好?

    動(dòng)畫渲染動(dòng)畫3D渲染技術(shù)需要應(yīng)對(duì)復(fù)雜的計(jì)算任務(wù)和精細(xì)的圖像處理,作為渲染技術(shù)人員,選擇合適的渲染模式,會(huì)直接影響制作效率和成品質(zhì)量。在主流的
    的頭像 發(fā)表于 04-15 09:28 ?1044次閱讀
    CPU<b class='flag-5'>渲染</b>、GPU<b class='flag-5'>渲染</b>、XPU<b class='flag-5'>渲染</b>詳細(xì)對(duì)比:哪個(gè)<b class='flag-5'>渲染</b>最快,哪個(gè)效果最好?

    2D圖形渲染緩慢怎么加快?

    我有一個(gè)圖形應(yīng)用程序,它似乎渲染屏幕的速度很慢。按下屏幕后,通常需要相當(dāng)長(zhǎng)的時(shí)間來(lái)更新,大約 50 或 100 毫秒。 在應(yīng)用程序啟動(dòng)時(shí),我看到一條錯(cuò)誤消息“GDK 無(wú)法創(chuàng)建 GL 上下文,回退
    發(fā)表于 04-02 06:46

    基于 HT 2D&amp;3D 渲染引擎的新能源充電樁可視化運(yùn)營(yíng)系統(tǒng)技術(shù)剖析

    在新能源汽車產(chǎn)業(yè)快速發(fā)展的浪潮中,充電樁作為關(guān)鍵配套設(shè)施,其運(yùn)營(yíng)管理的高效性和智能化愈發(fā)重要。圖撲軟件憑借基于 WebGL 和 Canvas 的 HT 2D3D 渲染引擎依托 WebGL
    的頭像 發(fā)表于 03-20 11:47 ?659次閱讀
    基于 HT <b class='flag-5'>2D</b>&amp;3<b class='flag-5'>D</b> <b class='flag-5'>渲染</b>引擎的新能源充電樁可視化運(yùn)營(yíng)系統(tǒng)技術(shù)剖析

    請(qǐng)問如何在Python中實(shí)現(xiàn)多線程與多進(jìn)程的協(xié)作?

    大家好!我最近在開發(fā)一個(gè)Python項(xiàng)目時(shí),需要同時(shí)處理多個(gè)任務(wù),且每個(gè)任務(wù)需要不同的計(jì)算資源。我想通過(guò)多線程和多進(jìn)程的組合來(lái)實(shí)現(xiàn)并發(fā),但遇到了一些問題。 具體來(lái)說(shuō),我有兩個(gè)任務(wù),一個(gè)是I/O密集型
    發(fā)表于 03-11 06:57

    請(qǐng)問rt-thread studio如何進(jìn)行多線程編譯?

    ,使用的是5800h+32g內(nèi)存+sn550 ssd,開啟16線程編譯時(shí)cpu的占用率也只能到30%,編譯完整個(gè)工程需要3分鐘 感覺多線程編譯設(shè)置沒有生效,有辦法提高編譯速度嗎
    發(fā)表于 02-19 08:30

    華為云 X 實(shí)例 CPU 性能測(cè)試詳解與優(yōu)化策略

    ? 2.2 Sysbench單線程CPU性能測(cè)試 ? 2.3 Sysbench多線程CPU性能測(cè)試(4線程) ? 2.4 高強(qiáng)度多線程CPU性能測(cè)試(8
    的頭像 發(fā)表于 12-30 14:52 ?1042次閱讀
    華為云 <b class='flag-5'>X</b> 實(shí)例 CPU 性能測(cè)試詳解與優(yōu)化策略

    socket 多線程編程實(shí)現(xiàn)方法

    在現(xiàn)代網(wǎng)絡(luò)編程中,多線程技術(shù)被廣泛應(yīng)用于提高服務(wù)器的并發(fā)處理能力。Socket編程是網(wǎng)絡(luò)通信的基礎(chǔ),而將多線程技術(shù)應(yīng)用于Socket編程,可以顯著提升服務(wù)器的性能。 多線程編程的基本概念 多線
    的頭像 發(fā)表于 11-12 14:16 ?1383次閱讀