plihui
初階會員
發表:88 回覆:96 積分:41 註冊:2003-07-03
發送簡訊給我
|
請問各位大大
求救..為什麼使用vector讀取Image,並將Image資訊轉換一維陣列表示時
產生中間那條斜線?
程式碼和輸出入圖如下
void Info_CM(TImage *Img,vector &pic)
{
int w=Img->Picture->Bitmap->Width;
int h=Img->Picture->Bitmap->Height;
for(int i=0;iCanvas->Pixels[i][j])>128)?1:0;
pic[i*h+j]=gray; }
}
//==========
void ExtractCF(TImage *Img,AnsiString file_name,int n,int m,int mode)
{
int w=Img->Picture->Bitmap->Width;
int h=Img->Picture->Bitmap->Height; int gray=0;//灰階值
vector pic;
for(int i=0;iCanvas->Pixels[i/h][i/w]=(TColor)RGB (255*pic[i],255*pic[i],255*pic[i]);
Application->ProcessMessages();
ShowMessage("完成");
}
輸入原圖(注意:方塊並無黑色斜線)
輸出圖(注意:方塊居然出現黑色斜線) 發表人 - plihui 於 2004/12/07 00:01:12
|
richtop
資深會員
發表:122 回覆:646 積分:468 註冊:2003-06-10
發送簡訊給我
|
plihui 您好: 您存圖時是以直行優先的方式(column major),但秀圖部分的指令很奇怪,似乎無法填滿整個影像?
建議先改下列部分試試。
for(int i=0;iCanvas->Pixels[i/h][i%w]=(TColor)RGB (255*pic[i],255*pic[i],255*pic[i]);
RichTop 敬上 =====*****
把數學當工具,可以解決問題;將數學變能力,能夠發現並解決問題!
=====#####
|
plihui
初階會員
發表:88 回覆:96 積分:41 註冊:2003-07-03
發送簡訊給我
|
引言:
請問各位大大
求救..為什麼使用vector讀取Image,並將Image資訊轉換一維陣列表示時
產生中間那條斜線?
程式碼和輸出入圖如下
void Info_CM(TImage *Img,vector &pic)
{
int w=Img->Picture->Bitmap->Width;
int h=Img->Picture->Bitmap->Height;
for(int i=0;iCanvas->Pixels[i][j])>128)?1:0;
pic[i*h+j]=gray; }
}
//==========
void ExtractCF(TImage *Img,AnsiString file_name,int n,int m,int mode)
{
int w=Img->Picture->Bitmap->Width;
int h=Img->Picture->Bitmap->Height; int gray=0;//灰階值
vector pic;
for(int i=0;iCanvas->Pixels[i/h][i/w]=(TColor)RGB (255*pic[i],255*pic[i],255*pic[i]);
*/
//改成
for(int i=0;iCanvas->Pixels[i][j]=(TColor)RGB (255*pic[i*h+j],255*pic[i*h+j],255*pic[i*h+j]); Application->ProcessMessages();
ShowMessage("完成");
}
輸入原圖(注意:方塊並無黑色斜線)
輸出圖(注意:方塊居然出現黑色斜線) 發表人 - plihui 於 2004/12/07 00:01:12
|
plihui
初階會員
發表:88 回覆:96 積分:41 註冊:2003-07-03
發送簡訊給我
|
引言:
請問各位大大
求救..為什麼使用vector讀取Image,並將Image資訊轉換一維陣列表示時
產生中間那條斜線?
程式碼和輸出入圖如下
void Info_CM(TImage *Img,vector &pic)
{
int w=Img->Picture->Bitmap->Width;
int h=Img->Picture->Bitmap->Height;
for(int i=0;iCanvas->Pixels[i][j])>128)?1:0;
pic[i*h+j]=gray; }
}
//==========
void ExtractCF(TImage *Img,AnsiString file_name,int n,int m,int mode)
{
int w=Img->Picture->Bitmap->Width;
int h=Img->Picture->Bitmap->Height; int gray=0;//灰階值
vector pic;
for(int i=0;iCanvas->Pixels[i/h][i/w]=(TColor)RGB (255*pic[i],255*pic[i],255*pic[i]);
*/
//改成
for(int i=0;iCanvas->Pixels[i][j]=(TColor)RGB (255*pic[i*h+j],255*pic[i*h+j],255*pic[i*h+j]); Application->ProcessMessages();
ShowMessage("完成");
}
輸入原圖(注意:方塊並無黑色斜線)
輸出圖(注意:方塊居然出現黑色斜線) 發表人 - plihui 於 2004/12/07 00:01:12
|