在網頁、軟件和游戲中,我們經常可以看到圖像的各種特技顯示,如中心擴散、百葉窗簾、右下推出等,這種動感圖像顯示,往往給人一種賞心悅目的感覺,給我們的應用程序增加了一些美感。在C++ Builder中,我們可以很容易地實現這些功能。下面以一個具體的例子,介紹實現中心擴散和百葉窗簾兩種顯示技巧,並說明在C++ Builder中處理圖像的基本方法。
在C++ Builder中新建一個工程,然後在窗體上添加一個Image圖像控件,把它的Picture屬性設置為一幅bmp圖像,調節Image控件尺寸與圖像的尺寸大小相同。再在窗體上添加兩個Button控件,把Button1的Caption屬性設置為“中心擴散”、Button2的Caption屬性設置為“百葉窗簾”。
1. 對於“中心擴散”的實現,我們利用一定的算法,通過一定的循環次數,每次顯示圖像的一部分,從圖像的中心位置開始顯示,直到顯示出圖像的整體。
在Button1的OnClick事件中加入以下代碼:
void _fastcall TForm1::Button1Click(TObject *Sender)
{
int i,left,top,width,height;
left = Image1->Left;
top = Image1->Top;
width = Image1->Width;
height = Image1->Height;
for (i = 0; i <= width; i++){
//通過圖像的坐標選定圖像的一部分
Image1->Left = left + (width - i)/2;
Image1->Top = top + height/2 - i*height/width/2;
Image1->Width = i;
Image1->Height = i*height/width;
Image1->Refresh();
}
}
2.對於“百葉窗簾”,我們可利用畫布(Canvas)提供的矩形拷貝(CopyRect)方法在不同畫布之間進行圖像復制來實現,該方法聲明如下:
void _fastcall CopyRect(const Windows::TRect &&Dest, TCanvas*Canvas, const Windows::TRect &&Source);
把參數Canvas指定的源畫布矩形區域Source復制到目標畫布Dest的矩形區域。利用這種方法,再通過一定的算法,即可實現“百葉窗簾”的特技顯示。
在Button2的OnClick事件中加入以下代碼:
void _fastcall TForm1::Button2Click(TObject *Sender)
{
int inum,icount,i,j;
Graphics::TBitmap *pBitmap = new Graphics::TBitmap();
pBitmap->Height = Image1->Height;
pBitmap->Width = Image1->Width;
inum =16; //這是百葉窗的葉數
icount = pBitmap->Height /inum;
for (i = 1; i < icount; i++)
for (j = 0; j <= inum; j++){
pBitmap->Canvas->CopyRect(Rect(0,icount*j + i - 1, pBitmap->Width,icount*j + i),Image1->Canvas, Rect(0, icount*j + i - 1,pBitmap->Width, icount*j + i));
Form1->Canvas->Draw(Image1->Left,Image1->Top,pBitmap);
}
delete pBitmap;
}
按F9運行以上程序,即可獲得所需要的“百葉窗簾”效果。
Image圖像控件還提供了另外一些很有用的屬性和方法,大家可以充分利用C++ Builder的幫助,掌握了這些屬性和方法,再利用一些程序算法,就可以隨心所欲地寫出各種圖像特技顯示的程序。在我們的應用程序開發中,就可以加入這些圖像特技顯示,為我們的應用程序增加一些光彩。