博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android 开发 -------- 自己定义View 画 五子棋
阅读量:6680 次
发布时间:2019-06-25

本文共 2275 字,大约阅读时间需要 7 分钟。

自己定义View  实现 五子棋 

配图:

代码:

package com.example.fiveson;import java.util.LinkedList;import java.util.List;import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.util.AttributeSet;import android.view.MotionEvent;import android.view.View;public class FiveSon extends View {	public FiveSon(Context context) {		super(context);		// TODO Auto-generated constructor stub		init(context, null);	}	public FiveSon(Context context, AttributeSet attrs) {		super(context, attrs);		// TODO Auto-generated constructor stub		init(context, attrs);	}	public FiveSon(Context context, AttributeSet attrs, int defStyleAttr) {		super(context, attrs, defStyleAttr);		// TODO Auto-generated constructor stub		init(context, attrs);	}		private Paint paint = new Paint();	private Paint circlePaint = new Paint();		// 旗子: 信息  代表 第几行 第几列?	private List
chesses = new LinkedList
(); private void init(Context context, AttributeSet attrs) { chesses.add(new int[]{3,5}); chesses.add(new int[]{3,6}); } int spacing = 100; @Override protected void onDraw(Canvas canvas) { // TODO Auto-generated method stub super.onDraw(canvas); int width = getWidth(); int height = getHeight(); //1 绘制 X 坐标 int num = width / spacing; paint.setColor(Color.BLACK); for(int i=0;i<=num;i++) { canvas.drawLine(spacing*i, 0, spacing*i, height, paint); } num = height/spacing; for(int i=0;i<=num;i++) { canvas.drawLine(0,spacing*i, width,spacing*i, paint); } //2 绘制Y 坐标 //3 绘制 旗子 if(!chesses.isEmpty()) { int count = chesses.size(); for(int i=0;i
=(spacing/2)) { colcc++; } if(rowcc>=(spacing/2)) { rowcc++; } // 推断什么时候add int len = chesses.size(); if(len>0) { boolean has = false; for(int i = len-1;i>=0;i--) { int[] chs = chesses.get(i); if(rowNum == chs[0] && colNum == chs[1]) { has = true; break; } } if(!has) { chesses.add(new int[]{rowNum,colNum}); invalidate(); } }else { chesses.add(new int[]{rowNum,colNum}); invalidate(); } isComsumed = true; }else { isComsumed = super.onTouchEvent(event); } return super.onTouchEvent(event); } }
你可能感兴趣的文章
VS2015 RTM与ASP.NET 5 RC1之坑
查看>>
@RequestMapping的Ant风格URL
查看>>
pitch yaw roll是什么
查看>>
python生成器 Generator
查看>>
Daily scrum[2013.12.09]
查看>>
mysql 切换数据库方案
查看>>
深浅copy
查看>>
网络osi
查看>>
关于Maya Viewport 2.0
查看>>
WINREG.H 编译出错
查看>>
Detours的使用准备
查看>>
30+有用的CSS代码片段
查看>>
PHP新手之学习类与对象(2)
查看>>
[Big Data - Kafka] Kafka设计解析(三):Kafka High Availability (下)
查看>>
Hibernate核心配置文件
查看>>
SpringBoot学习之一 Unable to find a single main class from the following candidates
查看>>
SpringCloud学习成长 四 断路器(Hystrix)
查看>>
Inventory Pro 装备拾取的实现
查看>>
Using SQL Server 2012 T-SQL New Features(转载)
查看>>
hihocoder [Offer收割]编程练习赛8
查看>>