+ -
当前位置:首页 → 问答吧 → 这个程序为什么实现不了渐变?

这个程序为什么实现不了渐变?

时间:2011-12-12

来源:互联网

if(nHeight<nWidth)
{
for (int i=0; i<nWidth; i++)
{
for (int j=0;j<nHeight;j++)
{
ptCur.x = i+rect.left ;
ptCur.y = j+rect.top;
//第1象限
if ((i>=nW2FZ1) && (j<=nH2FZ1))
{
nR=sqrt(double((i-nW2FZ1)*(i-nW2FZ1)+(nH2FZ1-j)*(nH2FZ1-j)));
if ((nR<nW2FZ1)&&(nR!=0))
{
r=rgbtRed+((ErgbtRed-rgbtRed)/nR)*i;
g=rgbtGreen+((ErgbtGreen-rgbtGreen)/nR)*i;
b=rgbtBlue+((ErgbtBlue-rgbtBlue)/nR)*i;
pDC->SetPixelV(ptCur, RGB(r,g,b));
}
}
//第2象限
if ((i<nW2FZ1) && (j<nH2FZ1))
{
nR=sqrt(double((nW2FZ1-i)*(nW2FZ1-i)+(nH2FZ1-j)*(nH2FZ1-j)));
if ((nR<nW2FZ1)&&(nR!=0))
{
r=rgbtRed+((ErgbtRed-rgbtRed)/nR)*i;
g=rgbtGreen+((ErgbtGreen-rgbtGreen)/nR)*i;
b=rgbtBlue+((ErgbtBlue-rgbtBlue)/nR)*i;
pDC->SetPixelV(ptCur, RGB(r,g,b));
}
}
//第3象限
if ((i<=nW2FZ1) && (j>=nH2FZ1))
{
nR=sqrt(double((nW2FZ1-i)*(nW2FZ1-i)+(j-nH2FZ1)*(j-nH2FZ1)));
if ((nR<nW2FZ1)&&(nR!=0))
{
r=rgbtRed+((ErgbtRed-rgbtRed)/nR)*i;
g=rgbtGreen+((ErgbtGreen-rgbtGreen)/nR)*i;
b=rgbtBlue+((ErgbtBlue-rgbtBlue)/nR)*i;
pDC->SetPixelV(ptCur, RGB(r,g,b));
}
}
//第4象限
if ((i>nW2FZ1) && (j>nH2FZ1))
{
nR=sqrt(double((i-nW2FZ1)*(i-nW2FZ1)+(j-nH2FZ1)*(j-nH2FZ1)));
if ((nR<nW2FZ1)&&(nR!=0))
{
r=rgbtRed+((ErgbtRed-rgbtRed)/nR)*i;
g=rgbtGreen+((ErgbtGreen-rgbtGreen)/nR)*i;
b=rgbtBlue+((ErgbtBlue-rgbtBlue)/nR)*i;
pDC->SetPixelV(ptCur, RGB(r,g,b));
}
}
}
}
}
那个高手指点下。。。。 这个程序哪里有问题? 就是实现不了圆的渐变。。。 出来的圆是乱七八糟的

作者: zpf1987823   发布时间: 2011-12-12

在线等 高手们出来吧!

作者: zpf1987823   发布时间: 2011-12-12

小伙子,不要以为会有人回复你的帖子,其实都是我一个人会的,不信我换个ID给你回复试试。

作者: fyzqzpd   发布时间: 2011-12-12

什么其实都是你一个人会的?

作者: zpf1987823   发布时间: 2011-12-12

热门下载

更多