Android+之小球跟着手指动
来源:互联网 发布:modbus数据帧格式 编辑:程序博客网 时间:2024/05/17 02:01
首先是介绍一下是怎么画图!
有两个类Canvas,Paint;
Canvas代表了“依附”了指定View的画布,Paint 代表了Canvas上的画笔;
如何在Android应用中绘制基本的集合图形,关键在于一个自定义View组件,要重写View组件的onDraw(Canvase)方法,接下来是在该 Canvas上绘制大量的几何图形,球形,方块,线,等各种形状!
画球: Canvas.drawCircle(x,y,len,paint)
为球绑上Touch事件;
原码如下:
CustomView类:
- public
void onCreate(Bundle savedInstanceState) - {
super.onCreate(savedInstanceState);- setContentView(R.layout.main);
//获取布局文件中的LinearLayout容器- LinearLayout root = (LinearLayout)findViewById(R.id.root);
//创建DrawView组件
final DrawView draw =new DrawView(this);
//设置自定义组件的最大宽度、高度- draw.setMinimumWidth(300);
- draw.setMinimumHeight(500);
//为draw组件绑定Touch事件- draw.setOnTouchListener(new OnTouchListener()
- {
@Override
public
boolean onTouch(View arg0, MotionEvent event)- {
//修改draw组件的currentX、currentY两个属性- draw.currentX = event.getX();
- draw.currentY = event.getY();
//通知draw组件重绘- draw.invalidate();
//返回true表明处理方法已经处理该事件
return
true;- }
- });
- root.addView(draw);
- }
view plain
- public
void onCreate(Bundle savedInstanceState) - {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- //获取布局文件中的LinearLayout容器
- LinearLayout root = (LinearLayout)findViewById(R.id.root);
- //创建DrawView组件
- final DrawView draw =new DrawView(this);
- //设置自定义组件的最大宽度、高度
- draw.setMinimumWidth(300);
- draw.setMinimumHeight(500);
- //为draw组件绑定Touch事件
- draw.setOnTouchListener(new OnTouchListener()
- {
- @Override
- public
boolean onTouch(View arg0, MotionEvent event) - {
- //修改draw组件的currentX、currentY两个属性
- draw.currentX = event.getX();
- draw.currentY = event.getY();
- //通知draw组件重绘
- draw.invalidate();
- //返回true表明处理方法已经处理该事件
- return
true; - }
- });
- root.addView(draw);
- }
DrawView类:
- public
float currentX = 40;
public
float currentY = 50;
/**- * @param context
- */
public DrawView(Context context)- {
super(context);
// TODO Auto-generatedconstructor stub- }
@Override
public
void onDraw (Canvas canvas)- {
super.onDraw(canvas);
//创建画笔- Paint p = new Paint();
//设置画笔的颜色- p.setColor(Color.GREEN);
//绘制一个小圆(作为小球)- canvas.drawCircle(currentX , currentY , 15 , p);
- }
- Android+之小球跟着手指动
- Android+之小球跟着手指动
- Android+之小球跟着手指动
- 让图片跟着手指动【Android Demo】
- 17、Android之SurfaceView实例自定义SurfaceView的应用——小球跟着手指移动
- Android小程序开发--跟随手指动的绿色小球
- Android开发之跟随手指的小球
- 【安卓】跟随手指动的小球
- Android跟随手指的小球
- android --小球跟随手指滑动
- Android 自定义view实例:跟踪手指小球
- Android---26---跟随手指移动的小球
- Android开发跟随手指的小球Demo
- Android拖动小球跟随手指移动Demo
- [Android]笔记3-跟随手指的小球
- android自定义组件-跟随手指的小球
- android开发跟随手指的小球
- 【Android应用实例之二】跟随手指的小球——自定义View应用
- Delphi语言基础
- 网页背景图自动伸缩
- 链表的排序和逆序
- 诡异的代码之数组越界造成的死循环
- 张小龙先生是谁?
- Android+之小球跟着手指动
- android 软件源码
- 动态规划-(1)
- Comet
- procedure 之应用
- 如何从应用跳到桌面
- 乔布斯斯坦福大学演讲
- VI编辑器的三种工作模式
- 用谷歌浏览器来当手机模拟器