Path绘制不规则图形和判断坐标的位置
来源:互联网 发布:淘宝交纳保证金 编辑:程序博客网 时间:2024/04/30 17:21
写这篇文章也是由于公司让我作一个非常困难但是非常炫的键盘开始的。本身我对绘图就不怎么明白,这不是赶鸭子上架吗?算啦,硬着头皮做吧。顺便给自己打个日记,以方便日后复习查找。
Path 是android 提供给我们绘制多边形和不规则图形的工具,其中不规则图形由直线和贝塞尔曲线构成。请看如下代码:
package com.jieer.test;import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.graphics.Path;import android.graphics.RectF;import android.graphics.Region;import android.view.MotionEvent;import android.view.View;import android.widget.Toast;public class PathView extends View {private Path p=new Path();Region re=new Region();public PathView(Context context) {super(context);// TODO Auto-generated constructor stub}@Overrideprotected void onDraw(Canvas canvas) {// TODO Auto-generated method stubsuper.onDraw(canvas);//起始顶点,绘制的方向为左下右上。p.moveTo(100, 100);p.lineTo(100, 150);//绘制一个贝塞尔曲线,第一个顶点是来控制曲线的弧度和方向,第二个顶点是弧线的结束顶点。p.quadTo(230, 150, 300, 200);p.quadTo(200, 150, 300, 200);p.quadTo(200, 120, 150, 100);p.close();//构造一个区域对象,左闭右开的。RectF r=new RectF();//计算控制点的边界p.computeBounds(r, true);//设置区域路径和剪辑描述的区域re.setPath(p, new Region((int)r.left,(int)r.top,(int)r.right,(int)r.bottom));Paint paint=new Paint();paint.setColor(Color.RED);paint.setStrokeWidth(1);paint.setStyle(Paint.Style.STROKE);//设置抗锯齿。paint.setAntiAlias(true);//paint.setFilterBitmap(true);canvas.drawPath(p, paint);}@Overridepublic boolean onTouchEvent(MotionEvent event) {// TODO Auto-generated method stub//判断所点击点(x,y)是否属于刚才绘制的图形区域。if(event.getAction()==MotionEvent.ACTION_DOWN){Toast.makeText(this.getContext(),String.valueOf(re.contains((int)event.getX(), (int)event.getY())), Toast.LENGTH_SHORT).show();}return true;}}
效果如图:
代码仅供参考,如有不对之处,请指正。
- Path绘制不规则图形和判断坐标的位置
- Android 判断一个点是否在封闭的Path内或不规则的图形内
- unity3d 屏幕坐标、鼠标位置、视口坐标和绘制GUI时使用的坐标
- 利用surfaceview和path绘制雨伞图形
- Android使用Path绘制相关的图形
- android 用Path 绘制各种图形,Path的方法解析
- android 用Path 绘制各种图形,Path的方法解析
- iOS在view中绘制不规则图形
- Android中图形的绘制-----自定义View(利用canvas和Path相结合)
- MFC基本图形的绘制(二)坐标映射
- Android 判断点是否在Path中(含不规则形状的Path)
- 绘制多边形和不规则按钮
- Android 不规则图形点击区域判断
- 利用SVG path绘制图形--基本图形
- 美轮美奂-随机绘制不同形状、色彩、大小、位置的图形
- 平辅不规则的图形
- 不规则图形的长投影
- 使用Path绘制图形,和绘制一条动画曲线(跟踪动画)
- 1428 双头蛇
- ASP.NET笔试题
- memcached基本处理流程
- 1429 删除中间的元素
- JPEG2000介绍
- Path绘制不规则图形和判断坐标的位置
- zoj1915
- 写程序就是我的图腾,如果发现直接无错误运行,说明我在梦里。
- C++经典
- Matlab 图像处理实验
- mssql日志清理方法
- ASCII码表
- JOJ 1329: Tree(重建二叉树)
- JS冒泡事件解决方案