在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

簡述OpenGL幀緩沖區多線(FBO)基本概念

電子工程師 ? 來源:CSDN技術社區 ? 作者:圖形碼農 ? 2021-03-24 15:56 ? 次閱讀

幀緩存:它是屏幕所顯示畫面的一個直接映象,又稱為位映射圖(Bit Map)或光柵。幀緩存的每一存儲單元對應屏幕上的一個像素,整個幀緩存對應一幀圖像。

幀緩沖區是指服務器(顯存)中存儲像素相關信息(顏色、深度)的存儲空間。系統提供了幀緩沖區對象包括多個緩沖區,有顏色緩沖區、深度緩沖區、模板緩沖區等。

一、緩存的分類

1. 顏色緩存

程序員繪圖所用的緩存,分為:

左、右緩存——用于立體感視圖(必須要有左緩存);
前、后緩存——用于雙緩存(必須要有前緩存);
4個輔助緩存——可選擇的、不可顯示(程序員可以自己定義和使用它們)。

2. 深度緩存

用來存儲每個象素的深度值,也稱為Z緩存。

3. 模板緩存

可以將作圖限制在屏幕的某些部分中進行。

4. 累積緩存

包含RGBA顏色數據,通常用于將一系列圖象累加成一幅最終的合成圖象。

象素不能直接繪制到累積緩存中,累加操作常常先在矩形塊中進行,然后再與顏色緩存交換數據。

二、緩存的操作

1. 清空緩存

(1). 指定要寫入緩存的清除值:

glClearColor()——為顏色緩存設置清除值(red,green,blue,alpha);
glClearIndex()——為顏色索引緩存設置清除值(index);
glClearDepth()——為深度緩存設置清除值(默認為1.0);
glClearStencil()——為模板緩存設置清除值(默認為0.0);
glClearAccum()——為累積緩存設置清除值(red,green,blue,alpha);

(2). 清除指定的緩存:

glClear(GLbitfield mask);
mask的值是GL_COLOR_BUFFER_BIT、GL_DEPTH_BUFFER_BIT、GL_STENCIL_BUFFER_BIT和GL_ACCUM_BUFFER_BIT等常數的按位邏輯或(OR)。可以一次清除多個緩存,如硬件支持同時清除這些緩存,則操作同時進行;否則,按順序清除各個緩存。

2. 為讀寫操作選擇顏色緩存

繪圖操作的結果可以放入任何一個顏色緩存中:前、后、左前、左后、右前、右后或任意輔存,程序員可選擇單個緩存作為繪圖目標或讀取目標。對繪制圖形而言,也可將目標同時繪制到幾個緩存中,用glDrawBuffer()函數來選擇將要寫入的緩存;用glReadBuffer()函數來選擇緩存,作為glReadPixels()、glCopyPixels()、glCopyTexImage*()和glCopyTexSubImage*()的應用目標。

3. 緩存的屏蔽(掩碼)

OpenGL在向激活的顏色、深度和模板緩存中寫入數據之前,需按下面函數指定的掩碼對這些數據進行屏蔽操作。每個掩碼要與對應的待寫數據進行按位邏輯與(AND)操作。
void glIndexMask(GLuint mask);
mask默認為1。若掩碼中出現1,則顏色索引模式中相應的位被寫入;而在0出現的位,
void glColorMask(GLboolean red,green,blue,alpha);
默認為GL_TRUE,表示相應的分量已寫入;若為GL_FALSE,則沒寫入。
void glDepthMask(GLboolean flag);
默認為GL_TRUE,表示深度緩存被激活用于寫操作;若為GL_FALSE,則取消。
void glStencilMask(GLuint mask);
默認為1,和顏色索引類似。

三、片元的測試和操作

在OpenGL確定了應該生成的片元及繪制顏色后,仍然需要幾個處理過程來控制如何將該片元作為一個象素繪制到幀緩存中,以及確定是否需要這樣做。本節描述了在放入幀緩存之前,片元所必須通過的完整測試集合,并且描述了在片元寫入時可能進行的最后操作。測試和操作按下列次序進行,若在前面的測試中片元被刪除,則不再進行后面的測試或操作。

1 .剪取測試

剪取測試只是使用屏幕矩形區域進行的模板測試的翻版,但是由于很容易用硬件快速實現,所以比以軟件方式執行的模板要快。

利用glScissor()函數,可以定義窗口中的一個矩形區域,并將作圖限制在其中。若片元落在該矩形區,則剪取測試通過,否則片元被刪除。

void glScissor(GLint x,GLint y,GLsizei width,GLsizei height);
glEnable(GL_SCISSOR_TEST):激活剪取測試;
glDisable(GL_SCISSOR_TEST):取消剪取測試。

默認情況下,矩形與窗口的大小相同,剪取處于取消狀態。

2. alpha測試

在RGBA模式下,根據alpha測試中的alpha值,來確定是接收還是拒絕一個片元。

glEnable/glDisable(GL_DEPTH_TEST):激活/取消alpha測試
glAlphaFunc設置alpha測試的參考值和比較函數:
void glAlphaFunc(GLenum func,GLclampf ref);
參考值ref取值在0和1之間截取。參數func的可能值及其含義如下:
GL_NEVER:總不接受該片元;GL_ALWAYS:總是接受該片元;
GL_LESS:若片元alpha < 參考alpha ,接受該片元;GL_LEQUAL:片元alpha≤參考alpha,接受;
GL_EQUAL:片元alpha=參考alpha,接受;GL_GEQUAL:片元alpha≥參考alpha,接受;
GL_GREATER:片元alpha > 參考alpha,接受;GL_NOTEQUAL:片元alpha≠參考alpha,接受;

3. 模板測試

只在有模板緩存的情況下才會發生。如果沒有模板緩存,則模板測試總能通過。模板化適用于這樣的測試,這種測試對存儲于模板緩存中的象素值與參考值進行比較,根據比較的結果,對模板緩存中的值進行修改。void glStencilFunc(GLenum func,GLint ref,GLuint mask);此函數為模板測試設置比較函數(func)、參考值(ref)以及掩碼(mask)。利用比較函數可以對參考值和模板緩存中的值進行比較,而比較僅適用于掩碼的相應位為1的位。比較函數的可能值與glAlphaFunc()中的比較函數的可能值相同,但含義相反。void gltencilOp(GLenum fail,GLenum zfail,GLenum zpass);

此函數說明當片元通過或未通過模板測試時,如何對模板緩存中的數據進行修正。三個參數fail、zfail、zpass可以為:
GL_KEEP:保持當前值
GL_ZERO:以0替換
GL_REPLACE:以參考值替換
GL_INCR:增加該值(在0~最大無符號整數值之間)
GL_DECR:減小該值(在0~最大無符號整數值之間)
GL_INVERT:對該值按位取反

若片元未通過模板測試,則應用fail函數;
若片元通過模板測試,但深度測試失敗,則應用zfail函數;
若片元通過模板測試,且通過深度測試,或沒有深度測試,則應用zpass函數。
默認情況下,三個模板操作都是GL_KEEP。
模板測試最典型的應用就是屏蔽掉屏幕的不規則區域,以避免在該區域作圖。

4. 深度測試

對于屏幕上的每個象素,深度緩存時刻追蹤視點與占據該象素的物體之間的距離。若通過了深度測試,輸入的深度值就將取代深度緩存中的相應值。

深度緩存通常用于消除隱藏表面的操作。最初,深度緩存通常是以距離視點盡可能遠的值來填充的,因此任何物體的深度都比初始狀態更近。

glEnalbe(GL_DEPTH_TEST);//激活深度測試
glClearDepth(1.0);//清除深度緩存
可以用glDepthunc()函數為深度測試選擇不同的比較函數。
void glDepthFunc(GLenum func);
此函數為深度測試設置比較函數。func的值必須為GL_NEVER、GL_ALWAYS、GL_LESS、GL_LEQUAL、GL_EQUAL、
GL_GEQUAL、GL_GREATER或GL_NOTEQUAL。如果z值與深度緩存中的值滿足確定的關系,則輸入片元通過深度測試。

5. 混合、抖動和邏輯操作

一旦輸入的片元通過了所有的測試,它就可以與顏色緩存中的當前內容按某種方式合并起來。最簡單的方法,也是默認操作,就是將當前值覆蓋掉。

在RGBA模式中,如果希望片元是半透明的或是消除了鋸齒現象的,程序員可以將該片元值與緩存中的值作一平均,即混合。

對于可用顏色較少的系統,可以以犧牲分辨率為代價,通過顏色值的抖動來增加可用顏色數量。抖動操作是和硬件相關的,OpenGL允許程序員所做的操作就只有打開或關閉抖動操作。實際上,若機器的分辨率已經相當高,激活抖動操作根本就沒有任何意義。要激活或取消抖動,可以用glEnable(GL_DITHER)和glDisable(GL_DITHER)函數。默認情況下,抖動是激活的。在顏色索引模式中,可以利用任意的按位邏輯操作,將輸入片元與已寫入的象素進行合成。

編輯:jq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • RGB
    RGB
    +關注

    關注

    4

    文章

    801

    瀏覽量

    58739
  • OpenGL
    +關注

    關注

    1

    文章

    85

    瀏覽量

    29337
  • 函數
    +關注

    關注

    3

    文章

    4346

    瀏覽量

    63022
  • 幀存
    +關注

    關注

    0

    文章

    3

    瀏覽量

    12406
收藏 人收藏

    評論

    相關推薦

    AMD Zen 4處理器悄然禁用循環緩沖區

    近日,AMD在更新BIOS后,對Zen 4架構的處理器進行了一項未公開說明的更改:禁用了循環緩沖區(Loop Buffer)功能。這一變化引發了業界和用戶的廣泛關注。 循環緩沖區作為CPU前端的一個
    的頭像 發表于 12-11 13:46 ?272次閱讀

    分享一個嵌入式通用FIFO環形緩沖區實現庫

    開源項目ringbuff ,是一款通用FIFO環形緩沖區實現的開源庫,作者MaJerle,遵循 MIT 開源許可協議。
    的頭像 發表于 10-23 16:20 ?560次閱讀
    分享一個嵌入式通用FIFO環形<b class='flag-5'>緩沖區</b>實現庫

    內存緩沖區和內存的關系

    內存緩沖區和內存之間的關系是計算機體系結構中一個至關重要的方面,它們共同協作以提高數據處理的效率和系統的整體性能。
    的頭像 發表于 09-10 14:38 ?787次閱讀

    單片機中的幾種環形緩沖區的分析和實現

    單片機中的幾種環形緩沖區的分析和實現一、簡介環形緩沖區(RingBuffer)是一種高效的使用內存的方法,它將一段固定長度的內存看成一個環形結構,用于存儲數據,能夠避免使用動態申請內存導致的內存碎片
    的頭像 發表于 08-14 08:39 ?1118次閱讀
    單片機中的幾種環形<b class='flag-5'>緩沖區</b>的分析和實現

    esp32-s3 uvc攝像頭緩沖區溢出是什么原因呢?

    板子是esp32-s3 n8r8 使用的是ESP IDF VSCode 擴展版本 v1.8.0 遇到的問題是,在改變分辨率時候(增大or減小)都會遇到提示緩沖區溢出的情況,我嘗試過增大緩沖區的內存分配,然而問題還是沒有得到解決。 請問這是什么原因呢
    發表于 07-19 07:35

    ESP8266有雙緩沖區嗎?

    我想實時傳輸一些信號的測量數據。信號的采樣周期為 1 ms。我想每 500 毫秒發送 2048 字節(一個數據包)。ESP8266有雙緩沖區(2x 2048字節)嗎?其想法是計數填充一個緩沖區(周期
    發表于 07-16 07:29

    創建DMA通道時,能否將DMA緩沖區的大小指定為8字節,并將DMA緩沖區的編號指定為1?

    創建 DMA 通道時,能否將 DMA 緩沖區的大小指定為 8 字節,并將 DMA 緩沖區的編號指定為 1?
    發表于 05-31 07:46

    stm32野火開發板上做USB通信,PC端USB的緩沖區和串口緩沖區的大小是多少?

    stm32野火開發板上做USB通信,用的CDC虛擬串口。 stm32端將ADC采集的數據通過USB傳給電腦,傳輸速率理論上是12Mbps,上位機是從PC端的串口緩沖區拿數據,用C#編寫的上位機將
    發表于 05-17 14:02

    具有八進制反相緩沖區的掃描測試設備數據表

    電子發燒友網站提供《具有八進制反相緩沖區的掃描測試設備數據表.pdf》資料免費下載
    發表于 05-17 09:58 ?0次下載
    具有八進制反相<b class='flag-5'>緩沖區</b>的掃描測試設備數據表

    實現穩健的微控制器到FPGA SPI接口: 雙緩沖區

    在介紹雙緩沖器之前,我們將簡要探討Verilog 脈寬調制器 (PWM) 的工作原理。這一點很重要,因為雙緩沖區最好被看作是硬件模塊 (如 PWM) 的可尋址接口。
    的頭像 發表于 05-16 09:36 ?808次閱讀
    實現穩健的微控制器到FPGA SPI接口: 雙<b class='flag-5'>緩沖區</b>!

    Stm32采用環形緩沖區接收rk3588的數據代碼

    Stm32采用環形緩沖區接收rk3588的數據代碼
    的頭像 發表于 05-15 10:10 ?706次閱讀

    交換機與路由器緩沖區:尋找完美大小

    *本文系SDNLAB編譯自瞻博網絡技術專家兼高級工程總監Sharada Yeluri領英 在路由器和交換機中,緩沖區至關重要,可以防止網絡擁塞期間的數據丟失。緩沖區到底要多大?這個問題在
    的頭像 發表于 04-11 16:56 ?1521次閱讀
    交換機與路由器<b class='flag-5'>緩沖區</b>:尋找完美大小

    交換芯片緩沖區大小是什么

    交換芯片緩沖區大小并不一定是固定的。緩沖區的設計和實現會根據芯片的具體型號、規格以及應用場景的不同而有所差異。一些交換芯片可能具有固定大小的緩沖區,以滿足特定的性能需求或成本限制。然而,隨著技術
    的頭像 發表于 03-18 14:42 ?695次閱讀

    使用UART FIFO緩沖區時,緩沖區中的數據有時會損壞的原因?

    我在使用 UART FIFO 緩沖區時遇到了以下問題。 問題描述: 當通過兩個 UART 通道使用完整的 UART FIFO 緩沖區并通過兩個通道進行通信時,緩沖區中的數據有時會損壞,例如,UART
    發表于 03-06 06:59

    沒有辦法通過FX3固件檢查緩沖區是卡住了還是已滿?

    使用通道 DMA 來獲得輸出 1080p60 所需的 FX3 數據帶寬。 在隨附的照片中,你可以看到多次寫入,然后突然間 WATERMARK 和 READY 同時斷言。 有沒有辦法通過FX3固件檢查緩沖區是卡住了還是已滿? 發生這種情況時,我能否附上一張 UART 調試
    發表于 02-23 08:01
    主站蜘蛛池模板: 中文字幕一区二区精品区 | 性过程很黄的小说男男 | 好男人午夜| 成人影院免费观看 | 天天操天天爱天天干 | 天天拍拍天天爽免费视频 | 性生大片免费观看无遮挡 | 精品一区二区三区三区 | 手机看片1024福利 | 亚洲三级在线 | 狠狠色丁香婷婷第六色孕妇 | 99久久99久久精品国产 | 午夜神马 | 欧美一级片免费在线观看 | 天天干夜夜爽天天操夜夜爽视频 | 国产日本三级 | 美女被网站免费看九色视频 | 成人精品亚洲人成在线 | 九九久久久久午夜精选 | 免费观看色视频 | 黄色免费在线网址 | se综合 | 国产精品免费拍拍1000部 | 午夜无码国产理论在线 | 亚洲天堂免费观看 | 亚洲卡1卡2卡新区网站 | 免费任我爽橹视频在线观看 | 亚洲综合五月天欧美 | 夜夜夜爽bbbb性视频 | 日本一级成人毛片免费观看 | 在线看片成人 | 天天玩夜夜操 | 国产色司机在线视频免费观看 | 一日本道加勒比高清一二三 | 国产精品爱久久久久久久三级 | 美女被免费网站91色 | 日本久久高清视频 | 1024手机免费看片 | 深夜偷偷看视频在线观看 | 国产午夜一区二区在线观看 | 亚洲福利一区二区三区 |