91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)

發布時間:2020-09-26 03:40:21 來源:網絡 閱讀:420 作者:makeapp628 欄目:移動開發
一張圖告訴你2048有多火

下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)


小3的悲劇
在每個階段手機里面都會有一兩款讓人愛不釋手的游戲存在,無論是在公車上、床鋪上、馬桶上還是在睡覺前、吃飯前、總會有讓你拿出手機打開它的欲望。大部分人被Flappy bird給蹂躪的體無完膚,生活不能自理。在這危難降臨的時刻,一款名為小3傳奇的數字益智游戲出現在我們的視野中,游戲既簡單又復雜,既單一又千變萬化,簡直就讓人停不下來!
但故事的發展是這樣的,小3傳奇的兩位開發者花了近一年半時間才開發出這個游戲的核心玩法,卻在其上架appstore后僅21天就被《1024》抄了過去。而《2048》則更為迅速,19歲的Gabriele Cirulli只用了一個星期改編前兩者游戲,卻獲得最大的成功,而小3卻不被人知;這類游戲從發布到現在,不管是app store還是android市場,下載量已經遠遠超越了千萬,網上各種版本的都有;
CocosEditor開源版
筆者歷時一個晚上,終于完成了cocos2d-js開源版本,編碼雖易,創意不易,且行且珍惜
此版本包含了網上流行的各種版本。包括原版,朝代版,金庸版,星座,豪車等等近10個版本,代碼開源,希望讀者基于開源代碼做出各種版本,供全名娛樂
運行demo需要配置好CocosEditor,暫不支持其他工具。demo是跨平臺的,可移植運行android,ios,html5網頁等,代碼是基于javascript語言,cocos2d-x游戲引擎,CocosEditor手游開發工具完成的。
本文共兩篇,第一篇分析原版,第二篇分析各種版本,本代碼僅供參考,有更好的實現方法可以評論中探討
已發布上線apk演示效果
幾個小時開發,一天審核上線,這就是CocosEditor開發游戲的速度
360應用市場(2048 聚合版):http://zhushou.#/detail/index/soft_id/1634607?recrefer=SE_D_2048%20%E8%81%9A%E5%90%88
豌豆莢應用市場 :http://www.wandoujia.com/apps/com.touchsnow.game.sudoku


CocosEditor版源代碼下載:

cocos2d-js源代碼請到集中營下載:http://blog.makeapp.co/?p=523

github版本管理:https://github.com/makeapp/cocoseditor-2048




Github里面大牛提供了各種語言的版本

包括(java  ,css,shell,python,objective-c等等),讀者可自行下載
https://github.com/search?q=2048&ref=cmdform




不同平臺下的效果圖:


windows

下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)



html5網頁

下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)


android平臺(各種主題版本)


下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)

下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)



代碼分析:

1初始化;進入游戲,初始化4*4表格,并隨機產生兩個2;

# 二維數組this.tables表格循環存入數據

#random1, random2 ,random11, random22四個隨機數可以確定兩個2的xy位置;

#方法newNumber里面,根據位置i,j和級別num可以確定一個新的數字;創建背景cell和cell上面的數字標簽cellLabel;并根據num確定是否顯示cellLabel;最后給cell關聯一個data數據;特別說明這里的number:num不是精靈上面的數字而是精靈的級別,比如number=11 則數字是1024


[javascript]view plaincopy下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)
  1. MainLayer.prototype.onEnter = function () {  

  2. //version

  3. this.versionNum = indexVersions;  

  4. this.indexVersion = VERSIONS[this.versionNum];  

  5. this.title.setString(this.indexVersion.name + "目標:" + this.indexVersion.array[this.indexVersion.array.length - 1] + "");  

  6. var random1 = getRandom(4);  

  7. var random2 = getRandom(4);  

  8. while (random1 == random2) {  

  9.        random2 = getRandom(4);  

  10.    }  

  11. var random11 = getRandom(4);  

  12. var random22 = getRandom(4);  

  13. this.tables = new Array(4);  

  14. for (var i = 0; i < 4; i++) {  

  15. var sprites = new Array(4);  

  16. for (var j = 0; j < 4; j++) {  

  17. if (i == random1 && j == random11) {  

  18.                sprites[j] = this.newNumber(i, j, 1);  

  19.            } elseif (i == random2 && j == random22) {  

  20.                sprites[j] = this.newNumber(i, j, 1);  

  21.            } else {  

  22.                sprites[j] = this.newNumber(i, j, 0);  

  23.            }  

  24.        }  

  25. this.tables[i] = sprites;  

  26.    }  

  27. this.totalScore = 0;  

  28. };  

  29. MainLayer.prototype.newNumber = function (i, j, num) {  

  30. var cell = cc.MySprite.create(this.rootNode, "5.png", this.getPosition(i, j), 1);  

  31. var cellLabel = cc.MySprite.createLabel(cell, "");  

  32. if (num > 0) {  

  33.        cell.setColor(COLOR[num]);  

  34.        cellLabel.setVisible(true);  

  35.        cellLabel.setString(this.indexVersion.array[num]);  

  36.        cellLabel.setFontSize(this.indexVersion.labelFontSize);  

  37.    } else {  

  38.        cellLabel.setVisible(false);  

  39.    }  

  40.    cell.data = {col: i, row: j, numberLabel: cellLabel, number: num};  

  41. return cell;  

  42. };  




2 四個方向算法;玩游戲的時候觸摸四個方向,表格就向四個方向合并靠攏leftCombineNumber,rightCombineNumber,downCombineNumber,upCombineNumber,四個方法函數的算法都是一樣的,我只分析一個leftCombineNumber;

第一步 相同數據疊加 :

#j從左到右變大,i從下到上變大;也就初始位置是左下角;

#如果該單元格級別不是空背景  cell.data.number != 0 ;

#從它的右邊開始var k = i + 1;  循環遍歷while (k < 4)  {k++};

#如果遍歷到單元格級別也不是空背景 if (nextCell.data.number != 0) 遍歷結束 k = 4; break;;

#而且如果發現兩個單元的級別一樣if (cell.data.number == nextCell.data.number)

#級別數據number刷新變化

cell.data.number += 1;

nextCell.data.number = 0;


第二步 填充空數據;

#同理第一步,如果是空背景if (cell.data.number == 0),也是循環遍歷while (k < 4)  {k++};

#如果遍歷到單元格級別不是空背景 if (nextCell.data.number != 0)  ,空背景獲得該單元格的數據,而該單元格則設為空背景;

cell.data.number = nextCell.data.number;
nextCell.data.number = 0;


[javascript]view plaincopy下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)
  1. //direction left

  2. MainLayer.prototype.leftCombineNumber = function () {  

  3. for (var j = 0; j < 4; j++) {  

  4. for (var i = 0; i < 4; i++) {  

  5. var cell = this.tables[i][j];  

  6. if (cell.data.number != 0) {  

  7. var k = i + 1;  

  8. while (k < 4) {  

  9. var nextCell = this.tables[k][j];  

  10. if (nextCell.data.number != 0) {  

  11. if (cell.data.number == nextCell.data.number) {  

  12.                            cell.data.number += 1;  

  13.                            nextCell.data.number = 0;  

  14. this.totalScore += SCORES[cell.data.number];  

  15.                        }  

  16.                        k = 4;  

  17. break;  

  18.                    }  

  19.                    k++;  

  20.                }  

  21.            }  

  22.        }  

  23.    }  

  24. for (j = 0; j < 4; j++) {  

  25. for (i = 0; i < 4; i++) {  

  26.            cell = this.tables[i][j];  

  27. if (cell.data.number == 0) {  

  28.                k = i + 1;  

  29. while (k < 4) {  

  30.                    nextCell = this.tables[k][j];  

  31. if (nextCell.data.number != 0) {  

  32.                        cell.data.number = nextCell.data.number;  

  33.                        nextCell.data.number = 0;  

  34.                        k = 4;  

  35.                    }  

  36.                    k++;  

  37.                }  

  38.            }  

  39.        }  

  40.    }  

  41. this.refreshNumber();  

  42. };  

  43. //direction right

  44. MainLayer.prototype.rightCombineNumber = function () {  

  45. for (var j = 0; j < 4; j++) {  

  46. for (var i = 3; i >= 0; i--) {  

  47. var cell = this.tables[i][j];  

  48. if (cell.data.number != 0) {  

  49. var k = i - 1;  

  50. while (k >= 0) {  

  51. var nextCell = this.tables[k][j];  

  52. if (nextCell.data.number != 0) {  

  53. if (cell.data.number == nextCell.data.number) {  

  54.                            cell.data.number += 1;  

  55.                            nextCell.data.number = 0;  

  56. this.totalScore += SCORES[cell.data.number];  

  57.                        }  

  58.                        k = -1;  

  59. break;  

  60.                    }  

  61.                    k--;  

  62.                }  

  63.            }  

  64.        }  

  65.    }  

  66. for (j = 0; j < 4; j++) {  

  67. for (i = 3; i >= 0; i--) {  

  68.            cell = this.tables[i][j];  

  69. if (cell.data.number == 0) {  

  70.                k = i - 1;  

  71. while (k >= 0) {  

  72.                    nextCell = this.tables[k][j];  

  73. if (nextCell.data.number != 0) {  

  74.                        cell.data.number = nextCell.data.number;  

  75.                        nextCell.data.number = 0;  

  76.                        k = -1;  

  77.                    }  

  78.                    k--;  

  79.                }  

  80.            }  

  81.        }  

  82.    }  

  83. this.refreshNumber();  

  84. };  

  85. MainLayer.prototype.downCombineNumber = function () {  

  86. for (var i = 0; i < 4; i++) {  

  87. for (var j = 0; j < 4; j++) {  

  88. var cell = this.tables[i][j];  

  89. if (cell.data.number != 0) {  

  90. var k = j + 1;  

  91. while (k < 4) {  

  92. var nextCell = this.tables[i][k];  

  93. if (nextCell.data.number != 0) {  

  94. if (cell.data.number == nextCell.data.number) {  

  95.                            cell.data.number += 1;  

  96.                            nextCell.data.number = 0;  

  97. this.totalScore += SCORES[cell.data.number];  

  98.                        }  

  99.                        k = 4;  

  100. break;  

  101.                    }  

  102.                    k++;  

  103.                }  

  104.            }  

  105.        }  

  106.    }  

  107. for (i = 0; i < 4; i++) {  

  108. for (j = 0; j < 4; j++) {  

  109.            cell = this.tables[i][j];  

  110. if (cell.data.number == 0) {  

  111.                k = j + 1;  

  112. while (k < 4) {  

  113.                    nextCell = this.tables[i][k];  

  114. if (nextCell.data.number != 0) {  

  115.                        cell.data.number = nextCell.data.number;  

  116.                        nextCell.data.number = 0;  

  117.                        k = 4;  

  118.                    }  

  119.                    k++;  

  120.                }  

  121.            }  

  122.        }  

  123.    }  

  124. this.refreshNumber();  

  125. };  

  126. //touch up

  127. MainLayer.prototype.upCombineNumber = function () {  

  128. for (var i = 0; i < 4; i++) {  

  129. for (var j = 3; j >= 0; j--) {  

  130. var cell = this.tables[i][j];  

  131. if (cell.data.number != 0) {  

  132. var k = j - 1;  

  133. while (k >= 0) {  

  134. var nextCell = this.tables[i][k];  

  135. if (nextCell.data.number != 0) {  

  136. if (cell.data.number == nextCell.data.number) {  

  137.                            cell.data.number += 1;  

  138.                            nextCell.data.number = 0;  

  139. this.totalScore += SCORES[cell.data.number];  

  140.                        }  

  141.                        k = -1;  

  142. break;  

  143.                    }  

  144.                    k--;  

  145.                }  

  146.            }  

  147.        }  

  148.    }  

  149. for (i = 0; i < 4; i++) {  

  150. for (j = 3; j >= 0; j--) {  

  151.            cell = this.tables[i][j];  

  152. if (cell.data.number == 0) {  

  153.                k = j - 1;  

  154. while (k >= 0) {  

  155.                    nextCell = this.tables[i][k];  

  156. if (nextCell.data.number != 0) {  

  157.                        cell.data.number = nextCell.data.number;  

  158.                        nextCell.data.number = 0;  

  159.                        k = -1;  

  160.                    }  

  161.                    k--;  

  162.                }  

  163.            }  

  164.        }  

  165.    }  

  166. this.refreshNumber();  

  167. };  




3 刷新數據和顏色;

上面的算法完成了,只是該精靈的data里面的數據發生了變化,但視覺上沒有任何變化,所以需要刷新數據和顏色

#新建一個空背景數組emptyCellList;

#又是循環二維數組this.tables

#得到單元格的文字標簽label,和級別cellNumber

#如果不是空背景cellNumber!=0,label顯示和設置文字內容和大小,同時如果檢測到是最高級別,游戲成功結束

#如果是空背景,label隱藏 emptyCellList添加該元素emptyCellList.push(cell);;


#得到一個emptyCellList后,如果發現該數組大小為空,也就無法再產生一個數字2了,游戲over;

#而如果數組大小不是空,隨機取一個位置randomCell,設置數據等級為0,數字為2,并播放縮放動畫runAction;


[javascript]view plaincopy下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)
  1. MainLayer.prototype.refreshNumber = function () {  

  2. var emptyCellList = [];  

  3. for (var i = 0; i < 4; i++) {  

  4. var numbers = " ";  

  5. for (var j = 0; j < 4; j++) {  

  6. var cell = this.tables[i][j];  

  7. var label = cell.data.numberLabel;  

  8. var cellNumber = cell.data.number;  

  9. if (cellNumber != 0) {  

  10.                cell.setColor(COLOR[cellNumber]);  

  11.                label.setString(this.indexVersion.array[cellNumber] + " ");  

  12.                label.setFontSize(this.indexVersion.labelFontSize);  

  13.                label.setVisible(true);  

  14. if (cellNumber == (this.indexVersion.array.length - 1)) {  

  15. //check success

  16. var toast = cc.Toast.create(this.rootNode, "成功到達:" + this.indexVersion.array[cellNumber], 2);  

  17.                    toast.setColor(cc.c3b(255, 0, 0));  

  18. this.rootNode.scheduleOnce(function () {  

  19.                        cc.BuilderReader.runScene("", "MainLayer");  

  20.                    }, 2)  

  21.                }  

  22.            } else {  

  23.                cell.setColor(COLOR[cellNumber]);  

  24.                label.setVisible(false);  

  25.                emptyCellList.push(cell);  

  26.            }  

  27.            numbers += "  " + cellNumber;  

  28.        }  

  29.        cc.log("numbers==" + numbers);  

  30.    }  

  31. //score

  32. this.scoreLabel.setString("分數:" + this.totalScore);  

  33. if (emptyCellList.length < 1) {  

  34. //check fail

  35. var toast = cc.Toast.create(this.rootNode, "失敗!", 2);  

  36.        toast.setColor(cc.c3b(255, 0, 0));  

  37. this.rootNode.scheduleOnce(function () {  

  38.            cc.BuilderReader.runScene("", "MainLayer");  

  39.        }, 2)  

  40.    } else {  

  41. //create random cell

  42. var randomCell = emptyCellList[getRandom(emptyCellList.length)];  

  43.        randomCell.data.number = 1;  

  44.        randomCell.data.numberLabel.setVisible(true);  

  45.        randomCell.data.numberLabel.setString(VERSIONS[this.versionNum].array[1] + "");  

  46.        randomCell.data.numberLabel.setFontSize(this.indexVersion.labelFontSize);  

  47.        randomCell.setColor(COLOR[1]);  

  48.        randomCell.runAction(cc.Sequence.create(cc.ScaleTo.create(0, 0.8), cc.ScaleTo.create(0.5, 1)));  

  49.    }  

  50. };  




4 觸摸檢測 兩個觸摸點this.pEnded this.pBegan 根據x y確定方向,再根據距離確定左右和上下;


[javascript]view plaincopy下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)下載量已超越千萬的爆紅游戲2048(同名小3傳奇、1024)源代碼解密和下載(第一篇)
  1. MainLayer.prototype.onTouchesEnded = function (touches, event) {  

  2. this.pEnded = touches[0].getLocation();  

  3. if (this.pBegan) {  

  4. if (this.pEnded.x - this.pBegan.x > 50) {  

  5. this.rightCombineNumber();  

  6.        }  

  7. elseif (this.pEnded.x - this.pBegan.x < -50) {  

  8. this.leftCombineNumber();  

  9.        }  

  10. elseif (this.pEnded.y - this.pBegan.y > 50) {  

  11. this.upCombineNumber();  

  12.        }  

  13. elseif (this.pEnded.y - this.pBegan.y < -50) {  

  14. this.downCombineNumber();  

  15.        }  

  16.    }  

  17. };  


思路很清晰簡單,游戲卻是簡約不簡單;




cocos2d-x跨平臺游戲引擎

cocos2d-x是全球知名的游戲引擎 ,引擎在全球范圍內擁有眾多開發者,涵蓋國內外各知名游戲開發商。目前Cocos2d-x引擎已經實現橫跨ios、Android、Bada、MeeGo、BlackBerry、Marmalade、Windows、Linux等平臺。編寫一次,到處運行,分為兩個版本 cocos2d-c++和cocos2d-html5 本文使用了后者;
cocos2d-x 官網:http://cocos2d-x.org/
cocos2d-x 資料下載  http://cocos2d-x.org/download



CocosEditor開發工具:

CocosEditor,它是開發跨平臺的手機游戲工具,運行window/mac系統上,javascript腳本語言,基于cocos2d-x跨平臺游戲引擎, 集合代碼編輯,場景設計,動畫制作,字體設計,還有粒子,物理系統,地圖等等的,而且調試方便,和實時模擬;

CocosEditor 下載,介紹和教程:http://blog.csdn.net/touchsnow/article/details/19070665;

CocosEditor官方博客:http://blog.makeapp.co/;



2048系列文章

2048源代碼解密和下載(第一篇 分析原版)

2048源代碼解密和下載(第二篇 分析各種版本)




傳送門(優質博文):

flappy bird游戲源代碼揭秘和下載

flappy bird游戲源代碼揭秘和下載后續---移植到android真機上

flappy bird游戲源代碼揭秘和下載后續---移植到html5網頁瀏覽器

flappy bird游戲源代碼揭秘和下載后續---日進5萬美元的秘訣AdMob廣告



PopStar(消滅星星)游戲源代碼下載、分析及跨平臺移植---第一篇(界面)

PopStar(消滅星星)游戲源代碼下載、分析及跨平臺移植---第二篇(算法)

PopStar(消滅星星)游戲源代碼下載、分析及跨平臺移植---第三篇(分數)

PopStar(消滅星星)游戲源代碼下載、分析及跨平臺移植---第四篇(關卡)



Fruit Ninja(水果忍者)游戲源代碼下載、分析(上)

Fruit Ninja(水果忍者)游戲源代碼下載、分析(中)

Fruit Ninja(水果忍者)游戲源代碼下載、分析(下)


筆者語:

想了解更多請進入官方博客,最新博客和代碼在官方博客首發;請持續關注,還有更多CocosEditor游戲源碼即將放出;

聯系筆者:zuowen@makeapp.co(郵箱) qq群:232361142


附錄:

整理各種版本的2048在線玩,狂歡起來吧;

1、2048原始版
http://gabrielecirulli.github.io/2048/
2、2048進階版(有乘法和繼續玩下去的功能)
http://baiqiang.github.io/2048-advanced/
3、2048漢化版1:甲乙丙丁
http://tiansh.github.io/2048/zhong/
4、2048漢化版2:商周秦漢
http://oprilzeng.github.io/2048/
5、2048喵喵版:色弱慎入
http://hczhcz.github.io/2048/20mu/
6、2048喪病版:8*8
http://cyberzhg.github.io/2048/
7、2048flappy版
http://hczhcz.github.io/Flappy-2048/
8、2048六角形版
http://baiqiang.github.io/2048-hexagon/
9、2048cross版
http://baiqiang.github.io/2048-cross/
10、2048double版
http://baiqiang.github.io/2048-double/
11、2048哲學版
http://learn.tsinghua.edu.cn:8080/2013310744/philosopher2048/

12、2048一步登天版
http://jennypeng.me/2048/
13、2048斐波那契數列版
http://mike199515.free3v.com/1597/2.htm
14、2048雙人對戰版
http://emils.github.io/2048-multiplayer/
15、2048變2版
https://www.prism.gatech.edu/~hli362/
16、2048直線版
http://tiansh.github.io/2048/
17、新增3D版的2048:
http://baiqiang.github.io/2048-3d/
18、2048的一個合集:
http://get2048.com/


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

西和县| 固安县| 阜平县| 林西县| 固镇县| 浦北县| 静宁县| 巴青县| 龙海市| 武清区| 香格里拉县| 景谷| 昌都县| 股票| 彭水| 弥渡县| 佛山市| 深泽县| 鄄城县| 遂溪县| 准格尔旗| 新源县| 南皮县| 普宁市| 富蕴县| 彭泽县| 蓬莱市| 成都市| 当雄县| 金塔县| 镇雄县| 平安县| 久治县| 太保市| 堆龙德庆县| 武义县| 武强县| 屏东市| 英山县| 云霄县| 同江市|