• <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>
            隨筆 - 96  文章 - 255  trackbacks - 0
            <2008年9月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            E-mail:zbln426@163.com QQ:85132383 長(zhǎng)期尋找對(duì)戰(zhàn)略游戲感興趣的合作伙伴。

            常用鏈接

            留言簿(21)

            隨筆分類(lèi)

            隨筆檔案

            SDL相關(guān)網(wǎng)站

            我的個(gè)人網(wǎng)頁(yè)

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 492238
            • 排名 - 38

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            作者:龍飛

                    我下面考慮的問(wèn)題,是用TextSurface反饋鼠標(biāo)事件的信息。我想到的第一個(gè)例子,很自然就是反饋鼠標(biāo)所在坐標(biāo)的位置。這里涉及到一個(gè)基礎(chǔ)的問(wèn)題,即鼠標(biāo)位置顯然不是用字符串表示的。SDL給我們的反饋信息是int,我們需要用TextSurface將int構(gòu)建成可以被blit到ScreenSurface上的面,需要做的第一件事情,是將int轉(zhuǎn)換為string。
                    我的思路是這樣的:首先找到int的數(shù)位數(shù);然后依次從高位讀取數(shù)字,之后將這個(gè)位去掉(通常減掉是最簡(jiǎn)單的);依次記錄這些數(shù)字,轉(zhuǎn)換成string,然后將這些數(shù)字“加”(字符串的合并)起來(lái)。
            頭文件如下:
            //UVi Soft (2008)
            //Long Fei (lf426), E-mail: zbln426@163.com

            //FileName: int_to_string.h

            #ifndef INT_TO_STRING_H_
            #define INT_TO_STRING_H_

            #include 
            <iostream>
            #include 
            <string>
            #include 
            <vector>

            int int_power(int baseint exp);
            std::
            string int_to_string(int num);

            #endif
                    其中,int_to_string()是我們需要構(gòu)建的函數(shù),int_power()是求一個(gè)數(shù)的整數(shù)冪的函數(shù)。這么簡(jiǎn)單的算法,我們就自己寫(xiě)吧。至于用到vector,按照我的思路,我們需要的數(shù)據(jù)結(jié)構(gòu)顯然應(yīng)該是“隊(duì)列”(先進(jìn)先出)。不過(guò)真得感謝STL,用vector顯然不是最優(yōu)化的,但是肯定是最“通俗”的,因?yàn)榧词故亲鳛榉菍?zhuān)業(yè)的隊(duì)列(或者棧),vector也已經(jīng)為我們提供了必要的方法,比如推入(push_back)。
                    下面我就把程序說(shuō)明夾在程序中間了。原因是本人英語(yǔ)太菜,簡(jiǎn)單描述還能忍,描述算法就有點(diǎn)不能忍了-_-!!!。另外,盡管我英語(yǔ)這水平,我還是希望程序里面別用中文注釋的好。這種事情,您見(jiàn)過(guò)一次亂碼,就總是得惡心一輩子。
            //UVi Soft (2008)
            //Long Fei (lf426), E-mail: zbln426@163.com

            #include 
            "int_to_string.h"

            int int_power(int baseint exp)
            {
                
            int result = 1;
                
            for (int i = exp; i > 0; i-- )
                    result
            *=base;
                
            return result;
            }
            這是個(gè)很簡(jiǎn)單的求冪的算法。其實(shí)我們?cè)诔绦蛑校恍枰玫角?0的n次冪,所以,實(shí)際上我們還可以寫(xiě)得更加有針對(duì)一點(diǎn)。
            std::string int_to_string(int num)
            {
                
            bool negative = false;
                
            if ( num < 0 ){
                    negative 
            = true;
                    num 
            = -num;
                }
            這開(kāi)始寫(xiě)轉(zhuǎn)換函數(shù)了。首先我們判定int是否為負(fù)。如果是,我們把它變成其相反數(shù),然后與正數(shù)一樣轉(zhuǎn)換,最后在前面加上“-”就OK了。
                int bitNum = 1;
                
            for ( int i = num; i > 9; i/=10 )
                    bitNum
            ++;
            bitNum是這個(gè)int的數(shù)位數(shù)。比如3就是1位,1024就是4位。
                std::vector<int> eachNum;
                
            for ( int i = bitNum, temp = num; i > 0; i-- ){
                    
            int highBit = int(temp/int_power(10, (i-1)));
                    eachNum.push_back(highBit);
                    temp
            -=(highBit*int_power(10, (i-1)));
                }
            我們通過(guò)vector數(shù)組紀(jì)錄每個(gè)數(shù)位上的數(shù)字,從高位到低位。需要說(shuō)明的是,n位的數(shù)字是10的n-1次方冪。比如1024是4位,而1000是10的3次方冪。所以,我們這里用的是i-1而非i。
                std::string str;
                
            if ( negative == true )
                    str 
            = "-";
                
            for ( std::vector<int>::iterator pTemp = eachNum.begin(); pTemp != eachNum.end(); pTemp++ ){
                    
            switch ( *pTemp ){
                        
            case 0:
                            str
            +="0";
                            
            break;
                        
            case 1:
                            str
            +="1";
                            
            break;
                        
            case 2:
                            str
            +="2";
                            
            break;
                        
            case 3:
                            str
            +="3";
                            
            break;
                        
            case 4:
                            str
            +="4";
                            
            break;
                        
            case 5:
                            str
            +="5";
                            
            break;
                        
            case 6:
                            str
            +="6";
                            
            break;
                        
            case 7:
                            str
            +="7";
                            
            break;
                        
            case 8:
                            str
            +="8";
                            
            break;
                        
            case 9:
                            str
            +="9";
                            
            break;
                        
            default:
                            
            break;
                    }
                }
                
            return str;
            }
            最后,我們用了STL的方法將每個(gè)數(shù)字轉(zhuǎn)換成std::string的字符串,然后將這些字符串合并起來(lái),作為函數(shù)的返回值。
                    我們?cè)谙乱还?jié)中將用TextSurface演示這個(gè)函數(shù)的作用,以及實(shí)現(xiàn)我們?cè)诒竟?jié)前面所提出的問(wèn)題。

            FeedBack:
            # re: SDL入門(mén)教程(九):4、int轉(zhuǎn)換為std::string 2008-07-20 14:50 zhou
            #include <sstream>
            #include <string>
            using namespace std;


            //具體函數(shù)有些忘了,不過(guò)使用sstream轉(zhuǎn)換數(shù)字肯定
            //比自己寫(xiě)好一些。因?yàn)榭梢詫?xiě)模板轉(zhuǎn)換float數(shù)字。
            string int_to_string(int num)
            {
            sstream<string > ss;
            ss << num;

            return ss.ToString();
            }

            //這是模板函數(shù),可能語(yǔ)法上有不正確的地方,你可以查查書(shū)籍就可以了,
            //重要的不是語(yǔ)法,而是思想。
            template<class T>
            string num_to_string(T num)
            {
            sstream<string > ss;
            ss << num;

            return ss.ToString();

            }  回復(fù)  更多評(píng)論
              
            # re: SDL入門(mén)教程(九):4、int轉(zhuǎn)換為std::string 2008-07-20 15:00 zhou
            我是zhou,歡迎到我的博客來(lái)。  回復(fù)  更多評(píng)論
              
            # re: SDL入門(mén)教程(九):4、int轉(zhuǎn)換為std::string[未登錄](méi) 2008-07-21 13:29 lf426
            感謝您的指教,我對(duì)C++標(biāo)準(zhǔn)庫(kù)的了解還是不多啊,其實(shí)我一直就覺(jué)得這樣的功能標(biāo)準(zhǔn)庫(kù)應(yīng)該提供的,之前一直沒(méi)有g(shù)oogle到。  回復(fù)  更多評(píng)論
              
            # re: SDL入門(mén)教程(九):4、int轉(zhuǎn)換為std::string[未登錄](méi) 2008-09-27 10:59 伊凡
            具體實(shí)現(xiàn)是:
            std::string int_to_string(int num)
            {
            std::ostringstream ss;
            ss << num;
            return ss.str();
            }
              回復(fù)  更多評(píng)論
              
            # re: SDL入門(mén)教程(九):4、int轉(zhuǎn)換為std::string[未登錄](méi) 2008-09-27 11:20 lf426
            謝謝。呵呵,這種看起來(lái)小的知識(shí)點(diǎn),很多書(shū)上都沒(méi)提到,但是其實(shí)很實(shí)用。  回復(fù)  更多評(píng)論
              
            # re: SDL入門(mén)教程(九):4、int轉(zhuǎn)換為std::string[未登錄](méi) 2009-01-01 20:10 Felicia
            這么實(shí)現(xiàn)也很簡(jiǎn)單:)

            string int2string(const int &a) {
            char buf[10];
            sprintf(buf, "%d", a);
            return string(buf);
            }
              回復(fù)  更多評(píng)論
              
            # re: SDL入門(mén)教程(九):4、int轉(zhuǎn)換為std::string 2010-08-25 09:22 DN
            @伊凡
            嗯 用流更方便  回復(fù)  更多評(píng)論
              
            # re: SDL入門(mén)教程(九):4、int轉(zhuǎn)換為std::string 2015-07-03 16:13 Haven
            sprintf就是呀  回復(fù)  更多評(píng)論
              
            精品国产综合区久久久久久| 亚洲精品无码专区久久久| 99久久精品免费| 99久久精品国产综合一区| 国内精品久久久久久久久电影网| 国产精品女同一区二区久久| 狠狠色伊人久久精品综合网| 欧美精品一区二区久久| 亚洲人成无码网站久久99热国产| 久久免费视频1| 久久无码一区二区三区少妇| 亚洲国产成人久久一区久久| 久久久久久曰本AV免费免费| 欧美牲交A欧牲交aⅴ久久 | 久久丫精品国产亚洲av不卡| jizzjizz国产精品久久| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区| 国产69精品久久久久9999| 久久强奷乱码老熟女网站| 久久www免费人成看片| 国产精品禁18久久久夂久| 91精品国产高清久久久久久国产嫩草| 久久国产成人| 色欲久久久天天天综合网| 久久九九精品99国产精品| 中文字幕日本人妻久久久免费| av色综合久久天堂av色综合在| 国产精品热久久无码av| 国产成人综合久久精品红| 久久99精品久久久久久久不卡| 国产成人综合久久精品尤物| 2021最新久久久视精品爱| 国产精品一久久香蕉产线看| 久久中文精品无码中文字幕| 久久久久人妻一区精品色| 精品久久久久久国产牛牛app| 7777久久久国产精品消防器材| 热久久国产精品| 久久伊人五月天论坛| 国产一区二区精品久久凹凸| 亚洲午夜久久久久妓女影院 |