• <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>

            C++在網頁設計中的應用

            在信息爆炸式增長的今天,每天都有大量新的網站誕生,每時每刻網上都傳遞著難以計數的信息。建立網站來進行自我宣傳和信息交流已成為一種新潮的媒體宣傳方式,多姿多彩的網頁也成為Internet中最為絢麗的部分。您也許已經注意到,在網絡速度不斷提高的今天,網站的站主們為了留住訪問者的視線,開始越來越多地在網頁中使用精美的動畫、交互式的表單以及其他網頁特效。不過我們要實現這些特效,一般都需要借助類似Photoshop、Flash這樣復雜的圖象設計軟件,而且由這些圖象軟件生成的特效,字節容量往往都會很大,這相對于目前并不理想的帶寬來說不能不算是個遺憾。當然,并不是所有的特效都需要龐大的圖象軟件才能完成,我們同樣可以通過編寫程序的方法來達到設計網頁特效的目的。下面,筆者就以C++Builder來設計動態網頁按鈕為例,來說明一下我們完全可以使用程序來制作網頁的特效?!   ?

            筆者在這里設計的動態網頁按鈕要實現的效果是,鼠標移動到按鈕上時,鼠標形狀變為手形,同時按鈕會動態地變成另外一幅畫面,從而將訪問者的視線瞬間吸引??;一旦鼠標離開按鈕之后,按鈕又恢復到以前狀態。在具體開發時,我們主要利用C++Builder提供的SpeedButton構件來顯示按鈕處在抬起、禁止、按下與保持按下的不同狀態,下面是其具體的設計步驟:

            1、首先選擇一張自己滿意的位圖作為按鈕的原始面貌

            將圖命名為one.bmp,接著可以用圖象制作軟件將one.bmp轉換為色彩更加亮麗的two.bmp,這個位圖就是按鈕在鼠標經過時顯示的圖形,另外為了能“強行”吸引訪問者的“眼球”,筆者同時還選取1個聲音文件名為crush.wav,以便讓鼠標移動到按鈕上時發出聲音來提醒用戶注意。

            2、做好準備工作后,我們下面就開始正式進行程序的原代碼編寫工作。

            打開一個純文本編輯軟件,并輸入下面的代碼:

            crush WAV crush.wav
            start BITMAP one.bmp
            start1 BITMAP two.bmp


            保存為資源文件app.rc。

            3、下面我們開始使用以C++Builder。

            首先啟動Builder,新建一個項目,并將資源文件app.rc添加進項目中。當然,大家也可以通過BIN目錄下的brcc32.exe將RC文件編繹為RES文件,然后用 #program resource "*.res" 語句將其聯編進項目中,筆者在這里采用了更簡單的前一種方法。在當前窗體上加入新的SpeedButton,取名為StartSpeedButton。屬性按下表設置:

            Caption 空
            Cursor crHandPoint
            Flat  true
            Hint
            Glyph None
            Showhint true

            接下來,打開所對應的頭文件,在其中的private項中增加:

            Graphics::TBitmap *one,*two;//定義位圖
            Char *chWavHandle;//定義聲音句柄


            然后在主表單的CPP文件的表單創鍵事件(onCreate)所對應的函數中先初始化位圖,

            one=new Graphics::TBitmap();
            two=new Graphics::TBitmap();


            下面,初始化后再載入位圖

            one->Handle=LoadBitmap(Hinstance, "one");//從內存中載入位圖
            two->Handle=LoadBitmap(Hinstance, "two");


            接著,再加載聲音文件

            HRSRC temp=FindResource(Hinstance,"crush", "WAV");//從內存中載入聲音
            HGLOBAL h=LoadResource(Hinstance,temp);
            ChWavHandle=(char *)LockResource(h);


            隨后我們再將浮動按鈕的畫面顯示為two.bmp的圖象

            StartSpeedButton->Glyph->Assign(two);

            當所有的初始工作結束以后,我們還應該及時釋放所占用的資源,操作時只要在主表單的OnDestroy事件所對應的函數中加入

            delete chWavHandle;
            delete two,one;

            到這里為止,鼠標形狀變化、按鈕突起及動態提示已經有了,下面所要做的工作就是完成圖形變化及聲音提示。在做這部分工作之前,可回想一下瀏覽網頁的情況。我們的動態按鈕的響應步驟應該是:鼠標移入按鈕時,圖形由第一幅圖變為第二幅圖,同時發出聲音來提示用戶;移出時圖形再變回原貌,但此時不發出聲響。因此應讓程序知道什么時候鼠標正好移入、什么時候正好移出。按照這個思路,我們可以在頭文件的private項中增加狀態變量:

            bool blStart;

            在主表單文件的OnCreate中為其設置初始值

            blStart=true;//在TRUE狀態下,一旦發生OnMouseMove事件就可以點亮按鈕
            選中SpeedButton按鈕,在其OnMouseMove事件所對應的函數StartSpeedButtonMouseMove()中增加
            if(blStart)//可以點亮按鈕
            {
            StartSpeedButton->Glyph->Assign(one);//加載第一幅圖
            // 通過chWavHandle句柄調用內存中聲音文件
            SndPlaySound(chWavHandle,SND_MEMORY|SND_SYNC);
            blStart=false;// 再發生OnMouseMove事件不可以點亮按鈕
            }


            當然,還必須在鼠標離開按鈕時再將圖形恢復為原貌。如何才能知道鼠標離開呢?比較原始的辦法自然是用鼠標的坐標位置來判斷,但這樣很費力。一個巧妙的招數是用包含(在位置上)此按鈕的其它部件的OnMouseMove事件來判斷(注意:選用的外圍部件相對于此按鈕來說需有足夠的縱深,否則,一旦鼠標移動太快,有可能會漏過OnMouseMove事件而發生紊亂。確決的辦法是,再加上更外圍的部件的OnMouseMove事件來雙保險)。

            以按鈕的外圍部件是主表單MainForm為例,在其OnMouseMove事件所對應的函數MainFormMouseMove()中加入

            if(!blStart)//鼠標正好由按鈕內移出
            StartSpeedButton->Glyph->Assign(two);// 加載第二幅圖
            blStart=true;//為鼠標重新進入按鈕作準備
            #include //在主表單CPP文件前部加入為SndPlaySound提供聲明的頭文件


            上面就是筆者使用C++Builder來實現簡單動態按鈕的設計,當然,如果您是一位編程愛好者的話,完全也可以通過編程來實現各種各樣的特殊效果的設計

            posted on 2007-12-20 16:03 lovetiffany 閱讀(1311) 評論(6)  編輯 收藏 引用

            評論

            # re: C++在網頁設計中的應用 2007-12-20 17:03 秦歌

            頂  回復  更多評論   

            # re: C++在網頁設計中的應用 2007-12-20 18:46 夢在天涯

            來圖,看的效果比較好  回復  更多評論   

            # re: C++在網頁設計中的應用 2007-12-20 23:34 Han

            這和C++在網頁設計中有什么關系呢?真沒看明白。
              回復  更多評論   

            # re: C++在網頁設計中的應用 2007-12-21 01:49 反傳統

            c++builder生成的exe如何嵌入網頁?!  回復  更多評論   

            # re: C++在網頁設計中的應用 2007-12-21 11:35 leonzhang

            不太現實~完全沒有必要~c++在web設計方面沒有優勢的
              回復  更多評論   

            # re: C++在網頁設計中的應用 2007-12-24 17:58 張三

            樓主是吃了沒事干嗎,浪費我的時間  回復  更多評論   

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆檔案

            網站收藏

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产一级持黄大片99久久| 久久亚洲精品成人无码网站| 亚洲日本久久久午夜精品| 2020最新久久久视精品爱| 99久久精品国内| 久久电影网2021| 国产成人久久精品麻豆一区| 久久美女网站免费| 国内精品久久久久久久久电影网| 日本精品久久久久中文字幕| 日本久久久久久中文字幕| 国产成人无码精品久久久久免费 | 久久99精品久久久久久野外| 色噜噜狠狠先锋影音久久| 久久99精品九九九久久婷婷| 日韩欧美亚洲综合久久影院Ds | 99久久国产亚洲高清观看2024 | 久久中文字幕人妻丝袜| 性高湖久久久久久久久| 99久久无码一区人妻a黑| 国产精品gz久久久| 99久久这里只精品国产免费| 日日躁夜夜躁狠狠久久AV| 久久电影网一区| 国产精品久久久久蜜芽| 久久伊人精品青青草原高清| 一本色综合久久| 国产91久久精品一区二区| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久久久久久亚洲精品| 久久人做人爽一区二区三区| 2021少妇久久久久久久久久| 久久这里只有精品视频99| 无码国内精品久久人妻蜜桃| 国产999精品久久久久久| 久久夜色精品国产噜噜亚洲AV| 94久久国产乱子伦精品免费| 久久久久久曰本AV免费免费| 国产精品综合久久第一页| 精品无码久久久久国产| 久久精品国产久精国产果冻传媒|