zoukankan      html  css  js  c++  java
  • 补上一篇计分功能

    计分的规则如下: 

    • 普通:各色小动物都是 10分
    • 直线特效(4个小动物同时消除)1.5倍
    • 爆炸特效(构成“L”型或“T”型)2倍
    • 直线+直线(“十字架”效果)3倍

        

    具体代码:

     1 function calscore(hor_num,ver_num,x,y){
     2     var addscore=0;
     3     //横向直线型
     4     if(hor_num>=3&&ver_num<3){
     5         if(hor_num==3){
     6             //comshape=0;
     7             addscore+=30;
     8         }
     9         else
    10             addscore+=hor_num*10*1.5;
    11     }
    12 
    13     //纵向直线型
    14     if(ver_num>=3&&hor_num<3){
    15          if(ver_num==3){
    16             //comshape=0;
    17             addscore+=30;
    18         }
    19         else
    20             addscore+=ver_num*10*1.5;
    21     }
    22     
    23     if(hor_num>=3&&ver_num>=3){
    24        
    25        if(x+1<=6&&x-1>=-1&&y-1>=-1&&y+1<=7){
    26                 //十字架型
    27                 if(imgdata[x-1][y]==imgdata[x][y]&&vis[x-1][y]>0&&imgdata[x][y+1]==imgdata[x][y]&&vis[x][y+1]>0
    28                     &&imgdata[x+1][y]==imgdata[x][y]&&vis[x+1][y]>0&&imgdata[x][y-1]==imgdata[x][y]&&vis[x][y-1]>0){
    29                         addscore+=(hor_num+ver_num-1)*10*3;
    30                     
    31                 }
    32                 //┳ ┑┍ ┕ ┙型
    33                 else if(imgdata[x][y-1]==imgdata[x][y]&&vis[x][y-1]>0&&imgdata[x+1][y]==imgdata[x][y]&&vis[x+1][y]>0
    34                        ||imgdata[x][y+1]==imgdata[x][y]&&vis[x][y+1]>0&&imgdata[x+1][y]==imgdata[x][y]&&vis[x+1][y]>0
    35                        ||imgdata[x][y-1]==imgdata[x][y]&&vis[x][y-1]>0&&imgdata[x-1][y]==imgdata[x][y]&&vis[x-1][y]>0
    36                        ||imgdata[x][y+1]==imgdata[x][y]&&vis[x][y+1]>0&&imgdata[x-1][y]==imgdata[x][y]&&vis[x-1][y]>0){
    37                              addscore+=(hor_num+ver_num-1)*10*2;
    38                 }
    39             }
    40         }
    41          
    42         presentscore+=addscore;
    43         var present_scorediv=document.getElementById("prescore");
    44         present_scorediv.innerHTML=presentscore;
    45         
    46        
    47 
    48           
    49 }
    View Code

    其他分散的代码如下:

    这里调用:

    这里判断是否通关

    定义:

    添加新的布局:

    样子:

    全部代码:

      1 <html>
      2 <head>
      3   <meta name="generator"
      4   content="HTML Tidy for HTML5 (experimental) for Windows https://github.com/w3c/tidy-html5/tree/c63cc39" />
      5   <meta charset="UTF-8" />
      6   <title>三消乐</title>
      7 <style type="text/css">
      8 body{background-image: url(imga.png);}
      9 #box {
     10   background-color: #55D88B;
     11    450px;
     12   height: 450px;
     13   position: relative;
     14   margin: 80px 350px;
     15 }
     16 #box div {
     17   float: left;
     18   position: relative;
     19   background-color: #E0DFE4;
     20   border: 2px;
     21   border-radius: 2px;
     22   height: 60px;
     23    60px;
     24   margin-top: 4px;
     25   margin-left: 4px;
     26 }
     27 #img {
     28   position: relative;
     29   float: left;
     30 }
     31 p{
     32    position: fixed;
     33    color: black;
     34    font-size:25px;
     35   color: #FFFF00;
     36 }
     37 #tagscore{
     38       position: fixed;
     39       background-color: #F0E0C6;
     40       border-radius: 5px;
     41       height: 40px;
     42        110px;
     43       top: 150;
     44       left: 80;
     45 }
     46 #prescore{
     47       position: fixed;
     48       background-color: #F0E0C6;
     49       border-radius: 5px;
     50       height: 40px;
     51        110px;
     52       top: 250;
     53       left: 80;
     54 }
     55 </style>
     56 </head> 
     57 <body   onload="init()">
     58  <script type = "text/javaScript" >
     59 var divy = new Array();
     60 var sum = 0,lastx = 0,lasty = 0,l_rnum = 0,o_dnum = 0,sum = 0,clickedimg = "",
     61 left_x = 0,left_y = 0,up_x = 0,up_y = 0;
     62 var img_lib = new Array("狐狸.png", "猫头鹰.png", "河马.png", "小鸡.png", "熊.png");//图片库
     63 var imgdata = new Array();//存储动物对应的数字
     64 var vis = new Array(); //标记数组
     65 var _clickedimg = new Array();//用来存点击的两张图片
     66 var targetscore=1000;
     67 var presentscore=0;
     68 var comshape=0;
     69 var s=0;
     70 function init() {
     71     //生成界面
     72     for (var i = 0; i < 7; i++) {
     73         imgdata[i] = new Array();
     74         for (var j = 0; j < 7; j++) {
     75             imgdata[i][j] ="";
     76         }
     77     }
     78     for (var i = 0; i < 7; i++) {
     79         vis[i] = new Array();
     80         for (var j = 0; j < 7; j++) {
     81             vis[i][j] = 0;
     82         }
     83     }
     84     var x = document.getElementById("box");
     85     for (var i = 0; i < 7; i++) {
     86         for (var j = 0; j < 7; j++) {
     87             imgdata[i][j] = parseInt(Math.random() * 10) % 5;//随机数,imgdata数组存的是数字
     88             x.innerHTML += "<div onclick=exchange(this," + i + "," + j + ")><img src=" + img_lib[imgdata[i][j]]+ "></div>";
     89         }
     90     }
     91     var tscorediv=document.getElementById("tagscore");
     92     tscorediv.innerHTML=targetscore;
     93     var present_scorediv=document.getElementById("prescore");
     94     present_scorediv.innerHTML=presentscore;
     95     //由于开始就是随机生成整盘动物,必须全盘扫描是否有满足可以消除的动物,并消除
     96     scanallimgs();
     97 }
     98 function exchange(obj, x, y) {
     99     var n = 0, m = 0;
    100     if (sum == 0) {//sum用来计算第几次点击
    101         lastx = x;//把第一次点击的照片存起来,方便后面的画图,不然找不到上一次点击的图片是什么
    102         lasty = y;
    103     }
    104     _clickedimg[sum] =imgdata[x][y]; //把交换的图片存起来
    105     sum++;
    106     if (sum >= 2 && lastx == x && lasty == y) sum = 1; //处理连续点击一样的图片
    107     if (sum == 2) {
    108         if(imgdata[x][y]==imgdata[lastx][lasty]){
    109              alert("它们长一样,待在原来地方就好!!");
    110         }
    111         else if (lastx == x || lasty == y) {
    112             if (Math.abs(lasty - y) == 1 || Math.abs(lastx - x) == 1) {
    113                 imgdata[x][y] = _clickedimg[0];//交换图片
    114                 imgdata[lastx][lasty] = _clickedimg[1];
    115                 divy = document.getElementsByTagName("div");
    116                 obj.innerHTML = '<img src="' + img_lib[imgdata[x][y]] + '">';
    117                 divy[lastx * 7 + lasty + 1].innerHTML = '<img src="' + img_lib[imgdata[lastx][lasty]] + '">';
    118                 n = scan(x, y);         //对两张图片分别扫描是否能够消除
    119                 m = scan(lastx, lasty);
    120                 if (n >= 1 || m >= 1) {   //只要其中一个可以消除,就满足交换
    121                     if(n==1&&m==1){
    122                         var s=document.getElementById("prescore");
    123                         s.innerHTML=presentscore+30;                 //连消一次
    124                     }
    125                     sum = 0;
    126                     _clickedimg[0] = _clickedimg[1] = 0;
    127                     removeimg();           //消除图片
    128                     alert("消除成功!!!新的动物马上赶来!!");
    129                     addimg();              //添加图片
    130                     scanallimgs();         //扫描随机添加上来的图片是否可以消除
    131                      if(presentscore>=targetscore){
    132                         alert("恭喜通关!!")
    133                         window.location.reload();
    134                     }
    135                 } else {
    136                     //两张图片都不满足交换,就还原位置
    137                     imgdata[x][y] = _clickedimg[1];
    138                     imgdata[lastx][lasty] = _clickedimg[0];
    139                     _clickedimg[0] = _clickedimg[1] = 0;
    140                     divy = document.getElementsByTagName("div");
    141                     obj.innerHTML = '<img src="' + img_lib[imgdata[x][y]] + '">';
    142                     divy[lastx * 7 + lasty + 1].innerHTML = '<img src="' + img_lib[imgdata[lastx][lasty]] + '">';
    143                     sum = 0;
    144                     alert("OMG!它们不能消除!交换失败!");
    145                     l_rnum = 0;
    146                     o_dnum = 0;
    147                 }
    148 
    149             } else {
    150                 alert("这两只不相邻!!!!!!"); //在同行或者同列不相邻
    151                 sum = 0;
    152             }
    153         } else {
    154             alert("这两只不相邻!!!!!!"); //不在同行也不在同列相邻
    155             sum = 0;
    156         }
    157     }
    158 }
    159 
    160 //扫描,以当前的点击的这个图片为中心,向左向右,向上向下
    161 function scan(x, y) {
    162     clickedimg = img_lib[imgdata[x][y]];
    163     var scan_lr = 1,scan_ud = 1;
    164     left_x = x;
    165     left_y = y;
    166     up_x = x;
    167     up_y = y;
    168     //如果该动物的左边与它自己相同,并且对应的标记数组大于0,就不继续扫描(因为代表已经扫过了一这行)
    169     if (y != 0 && img_lib[imgdata[x][y-1]] == clickedimg && vis[x][y - 1] > 0) {
    170         scan_lr = 0;
    171     }
    172     //如果该动物的上边与它自己相同,并且对应的标记数组大于0,就不继续扫描(因为代表已经扫过了一这列)
    173     if (x != 0 && img_lib[imgdata[x-1][y]] == clickedimg && vis[x - 1][y] > 0) {
    174         scan_od = 0;
    175     }
    176     if (scan_lr == 1) {
    177         for (var a = 0;; a++) {
    178             if (y - a < 0 || img_lib[imgdata[x][y-a]] != clickedimg) {
    179                 break;
    180             } else if (img_lib[imgdata[x][y-a]] == clickedimg) { //向左扫描
    181                 vis[x][y - a]++;
    182                 l_rnum++;
    183                 if (a != 0) left_y--;//记下与当前动物相同的最左边的动物,横向重置标记数组的时候是用循环从最左边开始
    184              }
    185         }
    186         for (var a = 1;; a++) {
    187             if (y + a > 6 || img_lib[imgdata[x][y+a]] != clickedimg) break;
    188             else if (img_lib[imgdata[x][y+a]] == clickedimg) { //向右扫描
    189                 vis[x][y + a]++;
    190                 l_rnum++;
    191             }
    192         }
    193 
    194         //向左与向右的相同动物加起来不超过三个,即横向不能消除,
    195         if (l_rnum < 3) {
    196             for (var i = 0; i < l_rnum; i++) {
    197                 vis[left_x][left_y + i] = vis[left_x][left_y + i] - 1;
    198             }
    199                  l_rnum = 0;
    200         }
    201     }
    202     if (scan_ud == 1) {
    203         for (var b = 0;; b++) {
    204             if (x - b < 0 || img_lib[imgdata[x-b][y]] != clickedimg) {
    205                 break;
    206             }
    207             else if (img_lib[imgdata[x-b][y]] == clickedimg) { //向上扫描
    208                 vis[x - b][y]++;
    209                 o_dnum++;
    210                 if (b != 0) up_x--;//记下与当前动物相同的最上边的动物,纵向重置标记数组的时候是用循环从最上边开始
    211             }
    212 
    213         }
    214         for (var b = 1;; b++) {
    215             if (x + b > 6 || img_lib[imgdata[x+b][y]] != clickedimg) break;
    216             else if (img_lib[imgdata[x+b][y]] == clickedimg) { //向下扫描
    217                 vis[x + b][y]++;
    218                 o_dnum++;
    219             }
    220         }
    221         //向下与向上的相同动物加起来不超过三个,即纵向不能消除,就要把标记数组减一,而不是设置为0,因为不能保证横向不能消除,为了保存那个共享的动物。
    222         if (o_dnum < 3) {  
    223             for (var j = 0; j < o_dnum; j++) {
    224                 vis[up_x + j][up_y] = vis[up_x + j][up_y] - 1;
    225             }
    226             o_dnum = 0;
    227         }
    228     }
    229     if (l_rnum >= 3 || o_dnum >= 3) {   //有一行或者有一列满足消除,即相同的动物大于等于3,返回1,表示可以交换
    230         calscore(l_rnum,o_dnum,x,y);
    231         l_rnum = 0;
    232         o_dnum = 0;
    233         return 1;
    234     } else {
    235         l_rnum = 0;
    236         o_dnum = 0;
    237         return 0;
    238     }
    239 }
    240 var comimgs=0;
    241 function calscore(hor_num,ver_num,x,y){
    242     var addscore=0;
    243     //横向直线型
    244     if(hor_num>=3&&ver_num<3){
    245         if(hor_num==3){
    246             //comshape=0;
    247             addscore+=30;
    248         }
    249         else
    250             addscore+=hor_num*10*1.5;
    251     }
    252 
    253     //纵向直线型
    254     if(ver_num>=3&&hor_num<3){
    255          if(ver_num==3){
    256             //comshape=0;
    257             addscore+=30;
    258         }
    259         else
    260             addscore+=ver_num*10*1.5;
    261     }
    262     
    263     if(hor_num>=3&&ver_num>=3){
    264        
    265        if(x+1<=6&&x-1>=-1&&y-1>=-1&&y+1<=7){
    266                 //十字架型
    267                 if(imgdata[x-1][y]==imgdata[x][y]&&vis[x-1][y]>0&&imgdata[x][y+1]==imgdata[x][y]&&vis[x][y+1]>0
    268                     &&imgdata[x+1][y]==imgdata[x][y]&&vis[x+1][y]>0&&imgdata[x][y-1]==imgdata[x][y]&&vis[x][y-1]>0){
    269                         addscore+=(hor_num+ver_num-1)*10*3;
    270                     
    271                 }
    272                 //┳ ┑┍ ┕ ┙型
    273                 else if(imgdata[x][y-1]==imgdata[x][y]&&vis[x][y-1]>0&&imgdata[x+1][y]==imgdata[x][y]&&vis[x+1][y]>0
    274                        ||imgdata[x][y+1]==imgdata[x][y]&&vis[x][y+1]>0&&imgdata[x+1][y]==imgdata[x][y]&&vis[x+1][y]>0
    275                        ||imgdata[x][y-1]==imgdata[x][y]&&vis[x][y-1]>0&&imgdata[x-1][y]==imgdata[x][y]&&vis[x-1][y]>0
    276                        ||imgdata[x][y+1]==imgdata[x][y]&&vis[x][y+1]>0&&imgdata[x-1][y]==imgdata[x][y]&&vis[x-1][y]>0){
    277                              addscore+=(hor_num+ver_num-1)*10*2;
    278                 }
    279             }
    280         }
    281          
    282         presentscore+=addscore;
    283         var present_scorediv=document.getElementById("prescore");
    284         present_scorediv.innerHTML=presentscore;
    285         //return presentscore
    286        
    287 
    288           
    289 }
    290 
    291 //添加图片
    292 function addimg() {   
    293     for (var i = 0; i < 7; i++) {
    294         for (var j = 0; j < 7; j++) {
    295             if (imgdata[i][j] == 9) {
    296                 imgdata[i][j] = parseInt(Math.random() * 10) % 5;  //随机添加
    297                 divy = document.getElementsByTagName("div");
    298                 _divnum = i * 7 + 1 + j;
    299                 divy[_divnum].innerHTML = '<img src="' +img_lib[imgdata[i][j]] + '">';
    300             }
    301         }
    302     }
    303 }
    304 
    305 //消除图片
    306 function removeimg() {
    307     var flag = 0;
    308     for (var i = 0; i < 7; i++) {
    309         for (var j = 0; j < 7; j++) {
    310             if (vis[i][j] > 0) {         //对应数组标记大于0就消除,并且把标记的数组标记为0
    311                 vis[i][j] = 0;
    312                 imgdata[i][j] =9;
    313                 divy = document.getElementsByTagName("div");
    314                 _divnum = i * 7 + 1 + j;
    315                 divy[_divnum].innerHTML = '<img src="' + "" + '">';//消除图片
    316                 flag = 1;
    317             }
    318         }
    319     }
    320     return flag;
    321 }
    322 
    323 //全盘扫描动物,整盘标记完再扫描,不然有些先删除了,后面扫描就会出问题
    324 function scanallimgs() {
    325     var c = 0,
    326     s = 1;
    327     while (s != 0) {  //s!=0表示上一个整盘动物与当前的整盘动物一样,即没有动物可以消除,s由removeimg()返回
    328         for (var i = 0; i < 7; i++) {
    329             for (var j = 0; j < 7; j++) {
    330                 scan(i, j);
    331             }
    332         }
    333         s = removeimg();
    334         addimg();
    335     }
    336 }
    337 </script>
    338 <div id="box" > 
    339 </div>
    340 <p style="top:80">过关要求</p>
    341 <div id="tagscore"></div>
    342 <p style="top:180">目前分数</p>
    343 <div id="prescore"></div>
    344 </body>
    345 </html>
    View Code
  • 相关阅读:
    UML--->用例图梳理
    UML--->活动图梳理
    论懂产品对程序员的重要性
    markdown时序图语法
    bootstrap 设置表格固定宽度 内容换行
    gitlab的本地搭建和部署使用
    layer.load的使用
    git fatal: remote origin already exists. 报错解决
    导出csv xls文件数字会自动变科学计数法的解决方式
    git常用命令
  • 原文地址:https://www.cnblogs.com/Lynn0814/p/5723803.html
Copyright © 2011-2022 走看看