線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1190
推到 Plurk!
推到 Facebook!

TChart组件绘制直方图出问题

尚未結案
必胜客86
一般會員


發表:2
回覆:1
積分:0
註冊:2012-03-20

發送簡訊給我
#1 引用回覆 回覆 發表時間:2012-03-26 09:41:41 IP:123.91.xxx.xxx 訂閱
这是我的代码,我申请了一个二维数组,第一维标记通道,第二维标记灰度级。我通过TChart组件绘制直方图,但是执行后,效果如下图:只是多了几条竖线而已,不知为何,请大大们指点下!
[code cpp]
for(n = 0; n < 256; n )
{
GrayClass[0][n] = 0; // gray
GrayClass[1][n] = 0; // red
GrayClass[2][n] = 0; // green
GrayClass[3][n] = 0; // blue
}
for(j = 0; j < bmp1 -> Height; j ) // j表示垂直方向
ptr = (TRGBTriple *)bmp1 -> ScanLine[j];
for(i = 0; i < bmp1 -> Width; i ) // i表示水平方向
{
//计算每个像素点灰度值
Gray = Ceil(ptr[i].rgbtRed * 0.299 ptr[i].rgbtGreen * 0.587 ptr[i].rgbtBlue * 0.114);
Red = ptr[i].rgbtRed;
Green = ptr[i].rgbtGreen;
Blue = ptr[i].rgbtBlue;
for(n = 0; n < 256; n ) // n表示灰度级
if(Gray == n)
{
GrayClass[0][n] = GrayClass[0][n] 1; //统计灰色在每个灰度级上像素点的数目
}
if(Red == n)
{
GrayClass[1][n] = GrayClass[1][n] 1; //统计红色在每个灰度级上像素点的数目
}
if(Green == n)
{
GrayClass[2][n] = GrayClass[2][n] 1; //统计绿色在每个灰度级上像素点数目
}
if(Blue == n)
{
GrayClass[3][n] = GrayClass[3][n] 1; //统计蓝色在每个灰度级上像素点数目
}
}
for(n = 0; n < 256; n )
{
Series1 -> AddXY(n, GrayClass[0][n], n, clBlack);
Series2 -> AddXY(n, GrayClass[1][n], n, clRed);
Series3 -> AddXY(n, GrayClass[2][n], n, clGreen);
Series4 -> AddXY(n, GrayClass[3][n], n, clBlue);
}
[/code]
系統時間:2024-11-21 22:26:21
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!