J2ME连连看基础功能源代码(含详细注释) - 编程入门网
作者 佚名技术
来源 NET编程
浏览
发布时间 2012-06-19
选中的块的数量增加1 selectTileNum++; //判别存储位置 switch(selectTileNum){ case 1: //第一次选择 firstRow = cRow; firstCol = cCol; break; case 2: //第二次选择 //选择同一个块,2个选择块都失去选中 if((firstRow == cRow) && (firstCol == cCol)){ selectTileNum = 0; return; } secondRow = cRow; secondCol = cCol; break; } } /** * 判断(r1,c1)块和(r2,c2)块中间是否为空行 * 不包含这两个块 * @param r1 块1的行号 * @param c1 块1的列号 * @param r2 块2的行号 * @param c2 块2的列号 * @return true代表为空,false代表不为空 */ private boolean isEmptyRow(int r1,int c1,int r2,int c2){ //判断是否位于同一行 if(r1 != r2){ return false; } //判断两个块的相对位置 if(c1 > c2){ //第一块位于右侧 for(int col = c1 - 1;col > c2;col--){ //如果有非空块 if(map[r1][col] != 0){ return false; } } }else{ //第一块位于左侧 for(int col = c2 - 1;col > c1;col--){ //如果有非空块 if(map[r1][col] != 0){ return false; } } } return true; } /** * 判断块(r1,c1)和块(r2,c2)之间是否是空列 * 不包含这两个块 * @param r1 块1的行号 * @param c1 块1的列号 * @param r2 块2的行号 * @param c2 块2的列号 * @return true代表为空,false代表不为空 */ private boolean isEmptyCol(int r1,int c1,int r2,int c2){ //判断是否位于同一列 if(c1 != c2){ return false; } //判断两个块的相对位置 if(r2 > r1){//第一个块在上方 for(int row = r1 + 1;row < r2;row++){ //如果有非空块 if(map[row][c1] != 0){ return false; } } }else{//第二个块在上方 for(int row = r2 + 1;row < r1;row++){ //如果有非空块 if(map[row][c1] != 0){ return false; } } } return true; } /** * 判断一个块是否为空 * @param r 块的行号 * @param c 块的列号 * @return true代表为空,false代表不空 */ private boolean isEmptyCell(int r,int c){ return map[r][c] == 0; } /** * 是否是一次转弯实现连线 * @return NO_LINK代表没有连线,其他值代表对应的连线类型 */ private int isOneCornerLink(int r1,int c1,int r2,int c2){ //先移动行,再移动列 if(isEmptyCell(r1,c2)){ //转折点为空 if(isEmptyRow(r1,c1,r1,c2) & isEmptyCol(r1,c2,r2,c2)){ return ONE_CORNER_FIRSTX; } |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
关于J2ME连连看基础功能源代码(含详细注释) - 编程入门网的所有评论