• <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年4月>
            303112345
            6789101112
            13141516171819
            20212223242526
            27282930123
            45678910

            E-mail:zbln426@163.com QQ:85132383 長期尋找對戰略游戲感興趣的合作伙伴。

            常用鏈接

            留言簿(21)

            隨筆分類

            隨筆檔案

            SDL相關網站

            我的個人網頁

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 492222
            • 排名 - 38

            最新評論

            閱讀排行榜

            評論排行榜

            作者:龍飛

                    我下面考慮的問題,是用TextSurface反饋鼠標事件的信息。我想到的第一個例子,很自然就是反饋鼠標所在坐標的位置。這里涉及到一個基礎的問題,即鼠標位置顯然不是用字符串表示的。SDL給我們的反饋信息是int,我們需要用TextSurface將int構建成可以被blit到ScreenSurface上的面,需要做的第一件事情,是將int轉換為string。
                    我的思路是這樣的:首先找到int的數位數;然后依次從高位讀取數字,之后將這個位去掉(通常減掉是最簡單的);依次記錄這些數字,轉換成string,然后將這些數字“加”(字符串的合并)起來。
            頭文件如下:
            //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()是我們需要構建的函數,int_power()是求一個數的整數冪的函數。這么簡單的算法,我們就自己寫吧。至于用到vector,按照我的思路,我們需要的數據結構顯然應該是“隊列”(先進先出)。不過真得感謝STL,用vector顯然不是最優化的,但是肯定是最“通俗”的,因為即使是作為非專業的隊列(或者棧),vector也已經為我們提供了必要的方法,比如推入(push_back)。
                    下面我就把程序說明夾在程序中間了。原因是本人英語太菜,簡單描述還能忍,描述算法就有點不能忍了-_-!!!。另外,盡管我英語這水平,我還是希望程序里面別用中文注釋的好。這種事情,您見過一次亂碼,就總是得惡心一輩子。
            //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;
            }
            這是個很簡單的求冪的算法。其實我們在程序中,只需要用到求10的n次冪,所以,實際上我們還可以寫得更加有針對一點。
            std::string int_to_string(int num)
            {
                
            bool negative = false;
                
            if ( num < 0 ){
                    negative 
            = true;
                    num 
            = -num;
                }
            這開始寫轉換函數了。首先我們判定int是否為負。如果是,我們把它變成其相反數,然后與正數一樣轉換,最后在前面加上“-”就OK了。
                int bitNum = 1;
                
            for ( int i = num; i > 9; i/=10 )
                    bitNum
            ++;
            bitNum是這個int的數位數。比如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)));
                }
            我們通過vector數組紀錄每個數位上的數字,從高位到低位。需要說明的是,n位的數字是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的方法將每個數字轉換成std::string的字符串,然后將這些字符串合并起來,作為函數的返回值。
                    我們在下一節中將用TextSurface演示這個函數的作用,以及實現我們在本節前面所提出的問題。
            posted on 2008-03-26 20:48 lf426 閱讀(4276) 評論(8)  編輯 收藏 引用 所屬分類: SDL入門教程語言基礎、數據結構與算法

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


            //具體函數有些忘了,不過使用sstream轉換數字肯定
            //比自己寫好一些。因為可以寫模板轉換float數字。
            string int_to_string(int num)
            {
            sstream<string > ss;
            ss << num;

            return ss.ToString();
            }

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

            return ss.ToString();

            }  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string 2008-07-20 15:00 zhou
            我是zhou,歡迎到我的博客來。  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string[未登錄] 2008-07-21 13:29 lf426
            感謝您的指教,我對C++標準庫的了解還是不多啊,其實我一直就覺得這樣的功能標準庫應該提供的,之前一直沒有google到。  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string[未登錄] 2008-09-27 10:59 伊凡
            具體實現是:
            std::string int_to_string(int num)
            {
            std::ostringstream ss;
            ss << num;
            return ss.str();
            }
              回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string[未登錄] 2008-09-27 11:20 lf426
            謝謝。呵呵,這種看起來小的知識點,很多書上都沒提到,但是其實很實用。  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string[未登錄] 2009-01-01 20:10 Felicia
            這么實現也很簡單:)

            string int2string(const int &a) {
            char buf[10];
            sprintf(buf, "%d", a);
            return string(buf);
            }
              回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string 2010-08-25 09:22 DN
            @伊凡
            嗯 用流更方便  回復  更多評論
              
            # re: SDL入門教程(九):4、int轉換為std::string 2015-07-03 16:13 Haven
            sprintf就是呀  回復  更多評論
              
            无码日韩人妻精品久久蜜桃| 午夜福利91久久福利| 日韩影院久久| 久久国产香蕉一区精品| 99久久免费国产精品| 中文字幕久久欲求不满| 曰曰摸天天摸人人看久久久| 国产精品女同一区二区久久| 国产精品丝袜久久久久久不卡 | 天堂久久天堂AV色综合| 2021最新久久久视精品爱 | 久久精品嫩草影院| 九九99精品久久久久久| 国内精品久久久久国产盗摄| 国产精品永久久久久久久久久 | 国内精品久久久久久99| 婷婷综合久久狠狠色99h| 国产L精品国产亚洲区久久| 欧美日韩中文字幕久久久不卡| 日日狠狠久久偷偷色综合0| 久久人与动人物a级毛片| 久久精品蜜芽亚洲国产AV| 久久午夜电影网| 日本高清无卡码一区二区久久| 精品人妻伦九区久久AAA片69| 欧美一区二区三区久久综| 99久久精品国产一区二区三区| 伊人久久国产免费观看视频| 乱亲女H秽乱长久久久| 激情综合色综合久久综合| 波多野结衣AV无码久久一区| 精品熟女少妇a∨免费久久| 精品久久人人做人人爽综合| 无码专区久久综合久中文字幕| 久久国产香蕉一区精品| 人妻少妇久久中文字幕| 亚洲国产天堂久久久久久| 国产精品久久免费| 久久亚洲国产成人影院| 99久久婷婷国产一区二区| 伊人久久精品无码二区麻豆|