• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            kenlistian

            厚積薄發. 勤為槳,思為帆

               :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理 ::
              73 隨筆 :: 4 文章 :: 22 評論 :: 0 Trackbacks


            幾個格式細節備記(混)


            typedef struct  _MediaType {
                GUID      majortype; 
                GUID      subtype;
                BOOL      bFixedSizeSamples;
                BOOL      bTemporalCompression;
                ULONG     lSampleSize;
                GUID      formattype;
                IUnknown  *pUnk;                  //not use
                ULONG     cbFormat;
                BYTE *pbFormat;
            } AM_MEDIA_TYPE;

            主要有
               majortype  媒體類型大致說明
               subtype    更一步的細致說明
               formattype 
                  包括有以下:其對應的不同的數據格式
                   FORMAT_None
                   FORMAT_DvInfo
                   FORMAT_MPEGVideo
                   FORMAT_MPEG2Video
                   FORMAT_VideoInfo
                   FORMAT_VideoInfo2 
                   FORMAT_WaveFormatEx  
                   GUID_NULL

              cbForamt成員指定了格式塊pbFormat的大小.
              pbFormat指針指向格式子塊。
                        pbFormat是一個void*的指針,因為格式塊會因為媒體類型
                        的不同而有不同的指向。如音頻填充的是WAVEFORMATEX結構
                 數據.

                 可以從中取出傳來的數據格式。
                

             

            //TWaveFormatEx 結構:
            TWaveFormatEx = packed record
              wFormatTag: Word;       {指定格式類型; 默認 WAVE_FORMAT_PCM = 1;}
              nChannels: Word;        {指出波形數據的通道數; 單聲道為 1, 立體聲為 2}
              nSamplesPerSec: DWORD;  {指定樣本速率(每秒的樣本數)}一般為8000
              nAvgBytesPerSec: DWORD; {指定數據傳輸的平均速率(每秒的字節數)} 每秒的字節數:
              nBlockAlign: Word;      {指定塊對齊(單位字節), 塊對齊是數據的最小單位}
              wBitsPerSample: Word;   {采樣大小(字節)}每個樣本的BIT數目,一般為16
              cbSize: Word;           {應該是該結構的大小}
            end;

            nChannels       :   對于pcm,其nchannels不超過2,對于非pcm格式,則超過2.
            nSamplesPerSec  :   通常為8kHz, 11.025 kHz, 22.05 kHz, and 44.1 kHz.
            nAvgBytesPerSec :   每秒傳送字節數 = nSamplesPerSec * nBlockAlign
            nBlockAlign     :   對齊字節  = nChannels * wBitsPerSample / 8
                                就是表示一個樣本的最小字節.
            wBitsPerSample  :   在格式默認情況下,一般為8,16,表示的是樣本的bit 數

            對于一個8位,11k傳輸的立體聲則
            nChannels  = 2
            nSamplesPerSec(每秒的樣本數) = 11025  就是取樣數
            nBlockAlign  = 2 * 8 / 8= 2           對齊字節,最小樣本字節數
            nAvgBytesPerSec = 11025 *  2 = 22050
            wBitsPerSample  = 8
             

             下面的圖列清楚從另一個方面表達樣本
             樣本1  樣本2 ...n
            8位單聲道 0聲道 0聲道
            8位立體聲 0聲道L         1聲道R  0聲道L  1聲R道
            16位單聲道 0聲道(低字節)    0聲道(高字節) 0聲道(低字節)    0聲道(高字節)
            16位立體聲

            0聲道(低字節)0聲道(高字節)1聲道(低) 1聲道(高) 

            同左

                                                                                                                                 
                                                    
                                               
            ---------

            waveform-audio 緩存格式     
              typedef   struct   {    
                      LPSTR     lpData;           //內存指針,放置音頻pcm樣本數據
                      DWORD     dwBufferLength;   //長度    
                      DWORD     dwBytesRecorded;  //已錄音的字節長度  
                      DWORD     dwUser;    
                      DWORD     dwFlags;    
                      DWORD     dwLoops;           //循環次數  
                      struct   wavehdr_tag* lpNext; //保留    
                      DWORD     reserved;           //保留
              }   WAVEHDR; 
             
              其中lpdata 即為pcm格式樣本數據。
             
            采樣大小為8位,則采樣的動態范圍為20*log(256)分貝=48db。
            樣本大小為16位,則采樣動態范圍為20*log(65536)大約是96分貝

            振幅大小:   20*log(A1/A2)分貝,A1,A2為兩個聲音的振幅。
            則對于的音頻:
                      8位       20 * lg( lpData[0] /256)
               16位      20 * lg( lpData[0]--lpData[1] / 65536)
             考慮到單雙道,還需要相應取出左右聲道的值。
             考慮到lg求值為負48至0之間,則在實際轉換中需要+48or96.


            樣本大小  數據格式      最大值  最小值
            8位PCM    unsigned int   256     0
            16位PCM   int            32767  -32767

             8位音頻是unsigned 存放波形,取振幅要-127.
             而16位因其存放為int 類型,直接套用公式.
             

            audiometer左右聲道音量探測程序(參考代碼(delphi版

             

            posted on 2009-01-05 14:16 kenlistian 閱讀(814) 評論(0)  編輯 收藏 引用 所屬分類: directx
            国产成人精品久久综合 | 色偷偷偷久久伊人大杳蕉| 亚洲人成伊人成综合网久久久| 久久亚洲中文字幕精品有坂深雪 | 狠狠色丁香婷综合久久| 九九久久精品国产| 新狼窝色AV性久久久久久| 91秦先生久久久久久久| 亚洲AV日韩精品久久久久久| 久久99精品久久久久久齐齐| 久久婷婷五月综合97色一本一本| 久久久噜噜噜久久| 久久国产精品久久久| 亚洲中文字幕无码一久久区| 色8激情欧美成人久久综合电| 久久免费精品视频| 狠狠88综合久久久久综合网| 亚洲午夜无码久久久久小说| 亚洲国产二区三区久久| 国内精品伊人久久久久av一坑| 久久无码中文字幕东京热| 狠狠综合久久综合中文88| 中文字幕亚洲综合久久| 国内精品人妻无码久久久影院 | 青青草原综合久久大伊人导航| 国产午夜精品理论片久久影视 | 色综合久久综合网观看| 97久久天天综合色天天综合色hd| 亚洲级αV无码毛片久久精品| 伊人精品久久久久7777| 婷婷久久综合| 久久青青色综合| 99久久无色码中文字幕人妻| 国内精品伊人久久久久777| 久久国产欧美日韩精品| 精品伊人久久大线蕉色首页| 亚洲精品乱码久久久久久自慰| 奇米影视7777久久精品| 99精品国产在热久久无毒不卡| 999久久久无码国产精品| 久久99国产精品一区二区|