• <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>
            隨筆 - 224  文章 - 41  trackbacks - 0
            <2010年8月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            享受編程

            常用鏈接

            留言簿(11)

            隨筆分類(159)

            隨筆檔案(224)

            文章分類(2)

            文章檔案(4)

            經(jīng)典c++博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            原文地址:http://www.vckbase.com/document/viewdoc/?id=1832

            關(guān)鍵字:外掛,連連看

            引言:

              最近在朋友那搞了個連連看游戲來玩玩,覺得還不錯,不過就是玩不過人家, 記得以前在一本書上看到過連連看外掛的做法,還比較簡單,自己還沒忘,于是下定決心, 自己做一個,然后……。哈哈,看誰還打得過我。
              好了,現(xiàn)在說下外掛的具體思路(我假設(shè)大家都知道連連看游戲的規(guī)則)。 這個外掛無非就是要電腦來幫我門找到相同的圖片并看他們是否連通。這里有兩個問題,一個 就是怎么讓電腦區(qū)別不同的圖片呢?這里有個簡單的辦法,就是在每個圖片中取5個點,然后 將這5個點的像素值相加做為這種圖片的ID,這樣一般不會出現(xiàn)重復(fù)的ID,如下圖所示例:

              這樣第一個問題就解決了,第二個問題就是怎么判斷它們是否連通,這個您研究下代碼就OK拉。 好了現(xiàn)在我們假設(shè)第二個問題已經(jīng)解決了,那么,我們只需要往連連看游戲的窗口的兩個相同且連通的圖片的地方發(fā)送兩個鼠標(biāo)單擊的消息 就OK了或者在他們上面畫兩個圈提示以下。下面是程序運行是的樣子:

            看到?jīng)],兩個相同的圖片被外掛程序標(biāo)記了顏色。或者你可以直接點擊“自動消除”來自動消除兩 個圖片。

            編程實現(xiàn):

              這里有個難點,就是該連連看的游戲的背景不是單色的,是一幅圖片,那我們怎么區(qū)分 到底是背景還是前景的圖片呢?我這里采用了個笨辦法,就是用調(diào)試的辦法去跟蹤,把每個區(qū)域的 背景也生成了它們的ID,到時比較一下就是了。這里就是我跟蹤得到的數(shù)據(jù),我把它門寫到了數(shù)組里 到時候用就是了。相關(guān)代碼如下:

            	//這里邊放的是背景的ID
            int BackGround[]={83886075,83886060,59434490,82188285,83820266,65305594,83754472,
            79584810,82141361,71323293,79582750,79584250,75889042,83818977,62589434,
            83175162,83332551,83553749,83818467,73624378,81705626,82759346,82496174,
            82100272,81070586,81468437,83754215,83885803,77729230,73148330,78524918,
            77217286,83754215,68069635,83597193,80299161,81172078,83027654,83503432,
            83686365,65042170,59778810,62410490,83356632,67567649,83523625,81967762,
            74584570,83885803,78520804,79577810,83027658,83818467,82220538,61620986,
            83820266,83687393,83555050,83818222,83886072};
            m_pBackGround=new int[BK_COUNT];
            for(int i=0;i< BK_COUNT;i++)
            {
            m_pBackGround[i]=BackGround[i];
            }			
            下面的函數(shù)就是根據(jù)圖片的行號和列號來生成圖片的ID,如果是背景圖片則返回一個標(biāo)志。
            //************該函數(shù)根據(jù)由x、y指定的行列返回該位置的方塊的ID號
            //如果是背景則返回 BACKGROUND
            int CLLK_CheatDlg::GetRectData(int x, int y)
            {
            CPoint ptPos[5];	//五個像素點
            COLORREF colorData[5];
            int nRetVal=0;
            int basicX,basicY;		//該方塊左上角的坐標(biāo)
            basicX=x*BLOCK_WIDTH;
            basicY=y*BLOCK_HEIGHT;
            //取該方塊的5個點判斷
            ptPos[0].x=basicX+BLOCK_WIDTH/2;    //中間點
            ptPos[0].y=basicY+BLOCK_HEIGHT/2;
            ptPos[1].x=ptPos[0].x;              //上邊
            ptPos[1].y=ptPos[0].y-5;
            ptPos[2].x=ptPos[0].x;
            ptPos[2].y=ptPos[0].y+5;            //下邊
            ptPos[3].x=ptPos[0].x-5;
            ptPos[3].y=ptPos[0].y;              //左邊
            ptPos[4].x=ptPos[0].x+5;            //右邊
            ptPos[4].y=ptPos[0].y;
            for(int i=0;i< 5;i++)
            {
            colorData[i] = GetPixel(m_MemDC.m_hDC,ptPos[i].x,ptPos[i].y);
            }
            for(i=0;i< 5;i++)
            {
            nRetVal+=colorData[i];
            }
            for(i=0;i< BK_COUNT;i++)
            {
            if(nRetVal==m_pBackGround[i])
            return BACKGROUND;
            }
            return nRetVal;
            }			
            接下來是判斷兩個圖片是否連通,代碼如下:
            BOOL CLLK_CheatDlg::IsLink(int x1, int y1, int x2, int y2)
            {
            //X直連方式
            if(x1==x2)
            {
            if(X1_Link_X2(x1,y1,y2))
            return TRUE;
            }
            //Y直連方式
            else if(y1==y2)
            {
            if(Y1_Link_Y2(x1,x2,y1))
            return TRUE;
            }
            //一個轉(zhuǎn)彎直角的聯(lián)通方式
            if(OneCornerLink(x1,y1,x2,y2))
            {
            return TRUE;
            }
            //兩個轉(zhuǎn)彎直角的聯(lián)通方式
            else if(TwoCornerLink(x1,y1,x2,y2))
            {
            return TRUE;
            }
            return FALSE;
            }
              這下主要的工作已做的差不多了,接下來就是挨個查找相同的圖片,并判斷它們是否連通的,如果是則提示或者 直接消除。這樣一個簡單的外掛就做成了,是不是不敢相信?

            其他的代碼請查看源文件。

            結(jié)束語

              這個程序還有點小BUG,就是有時會查不到可以消除的圖片,有可能就是獲取背景圖片的ID時沒有獲取 到準(zhǔn)確的值導(dǎo)致程序發(fā)送的消息得不到效果。如果大家有好的辦法可以自己去完善一下。

            posted on 2008-11-28 22:02 漂漂 閱讀(558) 評論(0)  編輯 收藏 引用 所屬分類: visual studio
            avtt天堂网久久精品| 精品国产91久久久久久久| 天堂无码久久综合东京热| 精品久久亚洲中文无码| 久久超碰97人人做人人爱| 中文字幕久久欲求不满| 久久人人爽人人爽人人片AV不| 久久久国产99久久国产一| 青青草原综合久久大伊人精品| 久久久久国产精品人妻| 国产欧美久久一区二区| 久久亚洲精品无码VA大香大香| 久久99国产精品成人欧美| 久久精品国产亚洲av日韩| 精品国产青草久久久久福利| 亚洲国产精品无码久久SM | 青青国产成人久久91网| 亚洲国产精品狼友中文久久久| 国产精品久久久久久久久鸭| 久久精品国产亚洲av高清漫画| 久久久久国色AV免费观看| 久久精品国产一区二区电影| 久久综合狠狠综合久久| 久久精品国产亚洲AV无码麻豆| 一本大道久久东京热无码AV| 国产日韩久久免费影院| 久久综合一区二区无码| 伊人久久五月天| 欧美久久一级内射wwwwww.| 91精品国产91热久久久久福利| 久久精品蜜芽亚洲国产AV| 久久发布国产伦子伦精品| 日产精品久久久一区二区| 一本色道久久99一综合| 国产亚洲综合久久系列| 潮喷大喷水系列无码久久精品| 一本色道久久综合狠狠躁| 亚洲伊人久久大香线蕉综合图片| 久久成人小视频| 亚洲AV无码成人网站久久精品大| 日韩AV无码久久一区二区|