青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

使用wxWidget中遇到的圖片存儲問題一二

1. 實驗室中CCD的實際色階為14位,獲取的原始圖像數(shù)據(jù)的每個值都存儲在一個字中,即存儲色階16位,也就是說最高兩位的數(shù)據(jù)一直為0,同時獲取的圖片信息僅僅是16色階的灰度圖,而采用wxWidget沒有辦法直接將16位的數(shù)值串保存為圖片格式,如tiff格式,那么如何將16位的數(shù)值串以圖片的形式進(jìn)行保存呢?

    經(jīng)過這么幾天的折騰總算是找到了一條解決的途徑,就是將16位的數(shù)值串轉(zhuǎn)化為8為的數(shù)值串,也許你會很快的想到這么一個方法,nValue*max(uint8)/max(uint16);用來表示轉(zhuǎn)化后的數(shù)值,不夠還是得考慮一下CCD的實際色階,由于是14位,因此可以采用這樣的方式nValue*max(uint8)/max(uint14);不過由于我們對于圖片的處理是直接對圖片的原始數(shù)據(jù)進(jìn)行處理,而轉(zhuǎn)化只是圖片在顯示屏上顯示的前提步驟,采用上述的方式雖然能夠相對很準(zhǔn)確的進(jìn)行轉(zhuǎn)化,但是需要花費一定的計算量,而通過近似的轉(zhuǎn)化能夠更快的進(jìn)行這個轉(zhuǎn)化過程,同時獲取得到的圖片依然具有較好的清晰度,下面細(xì)說一下我采用的方法:

   1: unsigned short nPicData16 = new unsigned short[nBufSize];   // nBufSize is the size to store pic
   2:  
   3: // to get the nPicData16
   4: // ..................
   5: // get the nPicData16
   6:  
   7: char *pcPicData8 = new char[nBufSize];
   8: for (size_t i = 0; i < nBufSize; ++i) {
   9:   pcPicData8[i] = (char)(nPicData16>>6);
  10: }
  11:  
  12:  

由于2^6在2^14中所占的比例較小因此可以采用這樣的近似的方法。(這種方法具體有什么作用或是缺陷還沒有細(xì)究,請各位看官給點看法

2. 順利將14位數(shù)值串轉(zhuǎn)化成為8為數(shù)值串后,嘗試的使用下列方式進(jìn)行圖片保存,發(fā)現(xiàn)結(jié)果一片黑,數(shù)值都為0了:

   1: // 結(jié)果發(fā)現(xiàn)存儲得到的save.bmp圖是24b的
   2: wxBitmap bitmap(pcPicData8,1392,1040,8);
   3: bitmap.SaveFile(wxT("save.bmp"),wxBITMAP_TYPE_BMP);
   4:  

因此猜想wxWidget對直接獲取的數(shù)據(jù)串進(jìn)行保存時采用的rgb的模式進(jìn)行保存,可能只會保存為24字節(jié)格式的圖片,也就是想要將圖片顯示到屏幕上時,也應(yīng)該采用24b的圖片。不過wxWidget對于圖片數(shù)據(jù)卻能夠讀取8位的圖片,但是再次采用上述的方式進(jìn)行存儲時,變成了32字節(jié)的了,(各位大蝦知不知道有沒有方法能夠直接保存8位圖的呢)。

于是采用了將這個8位的數(shù)值串分別賦值給R,G,B,用這種方式實現(xiàn)灰度圖的創(chuàng)建,然后再進(jìn)行保存,最終解決了問題。

   1: unsigned char *rgbData = new unsigned char[1392*1040*3];
   2: unsigned char *ptr1 = (unsigned char*) pcPicData8;
   3: unsigned char *ptr2 = rgbData;
   4: for (int i = 0; i < 1392*1040; ++i) {
   5:     *ptr2++ = *ptr1;   
   6:     *ptr2++ = *ptr1;
   7:     *ptr2++ = *ptr1++;
   8: }
   9: wxImage myImage(1392,1040,rgbData);
  10: myImage.SaveFile(wxT("save.bmp"),wxBITMAP_TYPE_BMP);

posted on 2012-06-26 17:51 鐘謝偉 閱讀(1970) 評論(12)  編輯 收藏 引用

評論

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 20:48 泡菜

貌似,wxWidget默認(rèn)保存tiff為24位圖(色階8位)的

wxWidget底層調(diào)用的,子庫為LibTIFF---一個開源C庫;需要復(fù)雜實用,直接調(diào)用C API...不過這樣很麻煩的.一般24位圖足夠?qū)嵱昧税?

文中提到的"實驗室中CCD的單個像素的分辨率為14位",有點沒理解?指色階14位,既32位圖么??看著有點暈  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 20:53 泡菜

上面回復(fù)有點錯誤,特別糾正下,應(yīng)該這樣說:

文中提到的"實驗室中CCD的單個像素的分辨率為14位",有點沒理解?指色階14位,既42位圖么??看著有點暈

顯卡一般實際輸出為32位圖(24位圖上加了個透明通道,色階還是8位的),個別支持48位圖(色階16位),例如DP口,可這是通過抖動/差值實現(xiàn)的,沒啥實際意義  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 21:03 鐘謝偉

@泡菜
那個專有的名詞是dynamic range A/D——14bit,指的是模數(shù)轉(zhuǎn)換范圍,我理解可能表示實際色階(文中說成單個像素的分辨率了,用詞不夠?qū)I(yè),不好意思),而數(shù)據(jù)存儲中是以16位色階存儲,也就是說16位中最高的兩位一直是0,而這個ccd只能夠獲取灰度圖,也就是沒有RGB信息,而wxWidget中沒有簡單的直接保存8位灰度圖的方式,于是采用了文中說的方式。  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 21:29 泡菜

@鐘謝偉
把代碼變?yōu)橄旅孢@個看看,保存下來的圖是否還是黑色的南??

1: // 結(jié)果發(fā)現(xiàn)存儲得到的save.bmp圖是24b的
2: wxBitmap bitmap(pcPicData8,1392,1040);
3: bitmap.SaveFile(wxT("save.bmp"),wxBITMAP_TYPE_BMP);  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 21:34 鐘謝偉

@泡菜
是的,還是黑色的,嘗試過了的  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 21:58 泡菜

static char pcPicData8[]= { 255 ,255 ,255 ,255 ,31,
255,255,255,31,255,255,255,31,255,255,255,
31,255,255,255,31,255,255,255,31,255,255,
255,31,255,255,255,31,255,255,255,25,243,
255,255,19,249,255,255,7,252,255,255,15,254,
255,255,31,255,255,255,191,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255,255,255,255,255,255,255,255,255,255,255,
255 };

wxBitmap bitmap(pcPicData8,32,32);
bitmap.SaveFile(wxT("save.bmp"),wxBITMAP_TYPE_BMP);

很久沒碰編程了,上面的代碼在wxWidget下是能正常生成,并保存的.說明你的pcPicData8轉(zhuǎn)化有問題,問題出在pcPicData8上.  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-26 22:24 泡菜

實驗室硬件CCD咋樣不清楚,整體代碼也沒看到,但感覺你對圖像色階的理解有點小問題;如果CCD是14位的(A/D),直接獲得的數(shù)據(jù)得通過轉(zhuǎn)換(抖動/插值)才能生成16位色階的圖片(48位圖).....大多軟件也不支持48位圖的.

tiff不太清楚,但bmp、JPG最高支持24位圖(8位色階),也是wxWidget默認(rèn)支持的;PNG好像本身格式支持48位圖,可wxWidget默認(rèn)也24位圖,實際上目前,在PC上還沒看到有完全支持48位圖形的程序.
  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-27 11:32 鐘謝偉

@泡菜
它是灰度圖,所以沒有48位之說。
你給出的例子是教程中的例子,能夠正常生成,不過pcPicData8的長度是128,而32*32=1024,對于它是怎么實現(xiàn)的感到困惑。也許采用的是補零??
另外我轉(zhuǎn)化存儲的數(shù)據(jù)上傳了  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-27 11:46 鐘謝偉

@泡菜
暈啊,不知道怎么上傳文件  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-27 13:09 泡菜

這是百度上,灰度圖像解釋:(針對RGB色彩空間來說)

完整的圖像,是由紅色綠色藍(lán)色三個通道組成的。紅色、綠色、藍(lán)色三個通道的縮覽圖都是以灰度顯示的。用不同的灰度色階來表示“ 紅,綠,藍(lán)”在圖像中的比重。通道中的純白,代表了該色光在此處為最高亮度,亮度級別是255。

俺在加點...8位色階數(shù)碼圖,實際上就是24位圖片(另一種表述方法),RGB三坐標(biāo),每個坐標(biāo)軸,分為256個刻度.例如(255,0,255)表示品紅,(0,0,255)表示藍(lán)色.圖片上的每個像素點,就是這樣描述出來的.

RGB色彩空間,是以RGB三個坐標(biāo)建立起的"立方體","灰度級"指"立方體"的對角線.灰度圖簡單點理解,可以簡單理解為,采用RGB色彩空間建立起來的圖形.
所以灰度圖,有48位圖(16位色階)的概念,只不過這個立方體相對8位色階,更大而已,每個坐標(biāo)的刻度從256級別,變大為65536級(2的16次方),可以表現(xiàn)65536*65536*65536種顏色;相對于8位色階(24位圖),256*256*256種顏色多得多爾

給你個連接自己看,雖然講的不太詳細(xì)
http://baike.baidu.com/view/1184366.htm

你對某些概念的確沒搞清楚,不過只要想學(xué)就好辦...

最后一貼,最終問題還是要靠自己解決....:)
  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-27 22:03 泡菜

本來說不回帖了,可感覺還是有些東西有點不知所以然,就把wxWidget的英文文檔調(diào)出來看,發(fā)現(xiàn)俺上面的例子也有點理解錯誤

wxBitmap的其中一個構(gòu)造函數(shù)為wxBitmap (const char bits[], int width, int height, int depth=1);英文說明
Creates a bitmap from the given array bits.
You should only use this function for monochrome bitmaps (depth 1) in portable programs: in this case the bits parameter should contain an XBM image.
For other bit depths, the behaviour is platform dependent: under Windows, the data is passed without any changes to the underlying CreateBitmap() API. Under other platforms, only monochrome bitmaps may be created using this constructor and wxImage should be used for creating colour bitmaps from static data.

其bits[]是XBM image,種基于ASCII編碼的圖像格式,不同于真彩色圖,沒采用RGB色彩空間,自然不能套用三原色的東西.
之前俺的例子是從一篇中文,文檔里提取的,他沒做詳細(xì)描述,俺想當(dāng)然的引用了,有點誤導(dǎo)....俺承認(rèn) :(

特別提一下,wxImage,他的其中一個構(gòu)造函數(shù),wxImage (int width, int height, unsigned char *data, unsigned char *alpha, bool static_data=false);英文文檔描述
Creates an image from data in memory.
If static_data is false then the wxImage will take ownership of the data and free it afterwards. For this, it has to be allocated with malloc.
Parameters:
width Specifies the width of the image.
height Specifies the height of the image.
data A pointer to RGB data ------------注意是RGB
alpha A pointer to alpha-channel data
static_data Indicates if the data should be free'd after use

注意到他與上面wxBitmap構(gòu)造函數(shù)聲明的不同了沒? 在wxImage這個上面用,自然沒問題

看樣遇見問題還是老老實實,求助英文文檔來的實際 :(

另,經(jīng)過查文檔,確認(rèn),wxWidget默認(rèn)生成圖像,的確是8位色階,24位真彩的哦  回復(fù)  更多評論   

# re: 使用wxWidget中遇到的圖片存儲問題一二 2012-06-28 09:32 鐘謝偉

@泡菜
額,一直看的是英文文檔,卻沒有深究,想當(dāng)然了,汗顏。
  回復(fù)  更多評論   


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2012年6月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

導(dǎo)航

統(tǒng)計

常用鏈接

留言簿(1)

隨筆檔案

IT網(wǎng)站

My Friends

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美本精品男人aⅴ天堂| 日韩视频免费观看高清完整版| 午夜久久资源| 国内精品久久久久久| 久久久亚洲午夜电影| 久久国内精品视频| 亚洲国产日韩一区| 亚洲精品视频在线看| 欧美视频在线播放| 欧美在线观看视频| 噜噜噜噜噜久久久久久91| 亚洲美女啪啪| 亚洲一区二区欧美| 亚洲国产视频一区| 在线视频免费在线观看一区二区| 国产欧美精品| 欧美国产激情| 国产伦精品一区| 欧美国产一区视频在线观看| 欧美日一区二区在线观看 | 国产精品va在线| 久久午夜精品一区二区| 欧美国产在线观看| 久久riav二区三区| 欧美精品国产一区| 久久精品国产2020观看福利| 欧美69wwwcom| 久久激情五月激情| 欧美人与禽性xxxxx杂性| 久久精品国产亚洲精品| 欧美精品尤物在线| 老司机67194精品线观看| 欧美日韩国产精品一卡| 久久综合九色综合欧美就去吻| 欧美日韩国产综合在线| 免费欧美在线| 国产精品美女一区二区| 亚洲欧洲日本国产| 好吊视频一区二区三区四区| 一区二区不卡在线视频 午夜欧美不卡' | 久久久爽爽爽美女图片| 欧美三日本三级少妇三99 | 亚洲主播在线播放| 免费成人你懂的| 久久久久久久欧美精品| 国产精品久久久久久久久久免费| 亚洲经典在线| 亚洲日本中文字幕| 久久久久久亚洲精品不卡4k岛国| 亚洲免费视频在线观看| 欧美日韩国产小视频| 亚洲国产成人精品久久| 在线观看91精品国产入口| 亚洲免费视频网站| 亚洲综合国产精品| 国产精品久久久久久亚洲调教| 99在线精品观看| 日韩亚洲欧美精品| 欧美精品在线观看一区二区| 亚洲国产mv| 亚洲靠逼com| 欧美精品粉嫩高潮一区二区| 亚洲国产电影| 一本到高清视频免费精品| 欧美成人免费在线观看| 亚洲国产精品成人久久综合一区| 亚洲电影免费| 欧美77777| 99re6热在线精品视频播放速度| 99精品视频免费观看| 欧美精品 国产精品| 亚洲精品一区二区三区不| 一区二区免费在线播放| 欧美午夜在线一二页| 亚洲私人影院| 久久精品一本久久99精品| 影音先锋国产精品| 欧美成人免费全部观看天天性色| 亚洲激情二区| 亚洲综合大片69999| 国语自产精品视频在线看| 久久在线观看视频| 妖精成人www高清在线观看| 午夜精品免费| 欧美激情亚洲激情| 在线一区免费观看| 久久免费黄色| 日韩亚洲精品视频| 国产精品视频99| 久久久久久久久综合| 亚洲精品日韩在线观看| 香蕉久久一区二区不卡无毒影院 | 国产精品无码永久免费888| 久久国产精品亚洲va麻豆| 亚洲第一精品夜夜躁人人爽| 亚洲专区一二三| 1000部国产精品成人观看| 欧美人与性动交α欧美精品济南到| 亚洲一级影院| 欧美激情亚洲自拍| 午夜日韩视频| 亚洲人成小说网站色在线| 国产精品久久久久aaaa樱花| 久久久久久久久蜜桃| 亚洲一级高清| 亚洲国产精品va在看黑人| 欧美淫片网站| 在线综合+亚洲+欧美中文字幕| 国产亚洲一区二区三区在线观看| 女女同性女同一区二区三区91| 亚洲一区二区三区精品在线观看| 欧美激情视频在线免费观看 欧美视频免费一 | 亚洲香蕉视频| 亚洲国产aⅴ天堂久久| 久久免费视频观看| 午夜在线视频观看日韩17c| 亚洲经典自拍| 国产一区二区三区四区| 欧美日韩在线播放| 欧美第一黄色网| 久久精品国产77777蜜臀| 亚洲欧美成人| 久久全国免费视频| 亚洲影视综合| 这里只有精品视频| 亚洲精品日韩一| 亚洲国产精品999| 国语精品中文字幕| 国际精品欧美精品| 国产日韩欧美夫妻视频在线观看| 欧美日韩国产影片| 欧美激情一区二区三区高清视频| 久久av二区| 久久精品国语| 久久天天躁狠狠躁夜夜爽蜜月| 欧美在线综合| 久久成人免费| 久久国产综合精品| 久久视频国产精品免费视频在线 | 99国内精品久久| 亚洲乱码精品一二三四区日韩在线 | 亚洲精品在线视频观看| 最新日韩在线视频| 亚洲精品综合| 一本在线高清不卡dvd| 欧美77777| 国产精品免费观看视频| 欧美区视频在线观看| 欧美激情亚洲一区| 欧美日韩国产123| 欧美日韩国产999| 国产精品乱子乱xxxx| 国产精品区一区| 国产在线高清精品| 一区二区视频免费在线观看| 加勒比av一区二区| 亚洲欧洲精品一区| 亚洲视频中文字幕| 欧美一区在线直播| 嫩模写真一区二区三区三州| 欧美福利视频一区| 99国内精品久久| 欧美一级视频精品观看| 久久精品99无色码中文字幕| 久久久久久穴| 欧美图区在线视频| 国产一区在线播放| 亚洲三级国产| 亚洲欧美自拍偷拍| 欧美不卡视频| 一本色道88久久加勒比精品| 欧美一级视频精品观看| 欧美不卡激情三级在线观看| 国产精品a久久久久久| 国产一区二区三区久久| 日韩一区二区精品| 欧美在线短视频| 亚洲国产一区二区三区a毛片| 亚洲砖区区免费| 美女啪啪无遮挡免费久久网站| 欧美日韩一区二区高清| 好看的亚洲午夜视频在线| 一区二区动漫| 蜜桃av综合| 亚洲免费一级电影| 欧美成年人视频网站| 国产美女精品免费电影| 91久久久国产精品| 欧美在线影院在线视频| 亚洲精品国产精品乱码不99 | 免费欧美在线| 午夜精品久久久久久| 欧美夫妇交换俱乐部在线观看| 国产精品亚发布| 9久re热视频在线精品| 两个人的视频www国产精品| 亚洲一区二区免费视频| 欧美伦理在线观看| 91久久久久久| 另类国产ts人妖高潮视频|