android簡單自定義View實現(xiàn)五子棋
本文實例為大家分享了android自定義View實現(xiàn)五子棋的具體代碼,供大家參考,具體內容如下
先說一下吧,android的自定義View就是自己實現(xiàn)一個類去繼承View,實現(xiàn)其中的方法,這里面我最感興趣的就是onDraw方法了,因為你要的樣式都要在這里面進實現(xiàn),看一下效果圖吧:

大概就是介個樣子的,長得丑不要緊,能用就行,畢竟只是簡單的了解一下嘛!
*protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
RectF rectF;
for(int i= pandingx ; i < pandingx*7 ; i+=size){
for(int z= pandingy ; z < pandingy*30 ; z+=size){
rectF = new RectF(i , z , i+size , z +size);
canvas.drawRoundRect(rectF , 1 ,1 ,paint);
}
}
for(int i = 0 ; i <list.size() ; i++){
int h = (int) list.get(i).get("x");
int s = (int) list.get(i).get("y");
if((int )list.get(i).get("flag") == 1) {
rectF = new RectF(h - size/2, s - size/2, h + size/2, s + size/2);
canvas.drawRoundRect(rectF, 50, 50, black);
}else{
rectF = new RectF(h - size/2, s - size/2, h + size/2, s + size/2);
canvas.drawRoundRect(rectF, 50, 50, white);
}
}
if(flag == 0) {
rectF = new RectF(x - size / 2, y - size / 2, x + size / 2, y + size / 2);
canvas.drawRoundRect(rectF, 50, 50, white);
}else{
rectF = new RectF(x - size / 2, y - size / 2, x + size / 2, y + size / 2);
canvas.drawRoundRect(rectF, 50, 50, black);
}
}
這里首先畫出了一個棋盤,下的棋子就放在了一個ArrayList中,里面放的是一個個的map,分別放了x,y坐標還有他的屬性(黑棋還是白棋),還有就是邊界的處理問題,很簡單我就不多說啦,畢竟是下棋的這個控件一定要是可以點的,不能只能看看那么簡單。
public boolean onTouchEvent(MotionEvent event) {
int action = event.getAction();
switch (action) {
case MotionEvent.ACTION_DOWN://按下
x = pandingx+size;
y = pandingy+size;
xx = event.getX();
yy = event.getY();
invalidate();
break;
case MotionEvent.ACTION_MOVE://移動
if(abs(event.getRawX()-xx)>=30){
if(event.getRawX()>xx&&JudgeRight() == true){
x += size;
xx = event.getRawX();
yy = event.getRawY();
}else if(JudgeLeft() == true){
x -= size;
xx = event.getRawX();
yy = event.getRawY();
}
invalidate();
}
if(abs(event.getRawY()-yy)>=30){
if(event.getRawY()>yy&&JudgeButtom() == true){
y += size;
xx = event.getRawX();
yy = event.getRawY();
}else if(JudgeTop() == true){
y -= size;
xx = event.getRawX();
yy = event.getRawY();
}
invalidate();
}
break;
case MotionEvent.ACTION_UP://松開
int i;
for( i = 0 ; i < list.size() ; i++){
if(x == (int)list.get(i).get("x")&&y == (int )list.get(i).get("y")){
toast.repice();
break;
}
}
if(i == list.size()) {
Map map = new HashMap();
map.put("x", x);
map.put("y", y);
map.put("flag", flag);
list.add(map);
flag = (flag + 1) % 2;
if(deal.setPiont((x-pandingx)/size , (y-pandingy)/size , flag+1)!=0){
if(deal.setPiont((x-pandingx)/size , (y-pandingy)/size , flag+1) ==1){
toast.winblack();
}
if(deal.setPiont((x-pandingx)/size , (y-pandingy)/size , flag+1) == 2){
toast.winwhite();
}
list.clear();
init();
}
x = -100;
y = -100;
invalidate();
}
break;
}
return true;
}
大概就是介個樣子的,實現(xiàn)了手指落下,滑動,還有抬起動作的監(jiān)聽,看上去有點亂,但是大概就是這么個意思,里面的deal類是我把已經下的棋子放到了一個二維數(shù)組中在里面單獨處理,來判斷他們到底有沒有五子連珠,好啦大概就只有這些了!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android自定義View實現(xiàn)簡單文字描邊功能
這篇文章主要為大家詳細介紹了Android自定義View實現(xiàn)簡單文字描邊功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12
使用RecyclerView添加Header和Footer的方法
RecyclerView雖然作為ListView的替代者有著較好的性能提升,但是ListView的一些常用功能卻沒有提供,比如我們平時會經常用到的addHeaderView,addFooterView,既然RecyclerView沒有提供這個方法,我們應該如何為列表添加頭部和底部呢,接下來通過本文給大家介紹2016-03-03
基于Android實現(xiàn)可滾動的環(huán)形菜單效果
這篇文章主要為大家詳細介紹了Android如何使用kotlin實現(xiàn)可滾動的環(huán)形菜單,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
基于Google ML模型開發(fā)Android物體檢測應用
ML Kit是Google提供的機器學習SDK,包含了一系列預訓練模型,可以在Android和iOS應用中快速添加機器學習功能,本項目基于Google ML模型開發(fā)Android物體檢測應用,首先對圖像中的物體進行分類檢測,獲取分類物體的位置區(qū)域,然后結合圖像標記,逐個獲取單個物體的標簽2024-07-07
Android車載多媒體開發(fā)MediaSession框架示例詳解
這篇文章主要為大家介紹了Android車載多媒體開發(fā)MediaSession框架示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10
Flutter插件開發(fā)之HmsScanKit實現(xiàn)示例詳解
這篇文章主要為大家介紹了Flutter插件開發(fā)之HmsScanKit實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11

