Android自定义View实现心形图案
更新时间:2021年09月27日 15:39:10 作者:_万能的博哥
这篇文章主要为大家详细介绍了Android自定义View实现心形图案,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了Android自定义View实现心形的具体代码,供大家参考,具体内容如下
通过继承View实现的❤形
在绘制心形需要Path类中的两个重要方法分别是:moveTo、cubicTo
moveTo 不会进行绘制,只用于移动移动画笔。
lineTo 用于进行直线绘制。
quadTo 用于绘制圆滑曲线,即贝塞尔曲线。
cubicTo 同样是用来实现贝塞尔曲线的。
具体实现:
public class HeartView extends View { private int mMeasureWidth; private int mWidthMode; private int mMeasureHeight; private int mHeightMode; private Paint paint; public HeartView(Context context) { super(context); } public HeartView(Context context, AttributeSet attrs) { super(context, attrs); paint = new Paint();//实例画笔 paint.setAntiAlias(true);//抗锯齿 paint.setStrokeWidth(2);//画笔宽度 paint.setColor(Color.RED);//画笔颜色 paint.setStyle(Paint.Style.FILL);//画笔样式 } /** * 测量 */ @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); mWidthMode = MeasureSpec.getMode(widthMeasureSpec); mHeightMode = MeasureSpec.getMode(heightMeasureSpec); mMeasureWidth = MeasureSpec.getSize(widthMeasureSpec); mMeasureHeight = MeasureSpec.getSize(heightMeasureSpec); if (mWidthMode == MeasureSpec.AT_MOST && mHeightMode == MeasureSpec.AT_MOST) { setMeasuredDimension(200, 200); } else if (mWidthMode == MeasureSpec.AT_MOST) { setMeasuredDimension(200, mMeasureHeight); } else if (mHeightMode == MeasureSpec.AT_MOST) { setMeasuredDimension(mMeasureWidth, 200); } else { setMeasuredDimension(mMeasureWidth, mMeasureHeight); } } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); int width = getWidth();//获取屏幕宽 int height = getHeight();//获取屏幕高 /** * 绘制心形 */ //左半面 Path path = new Path(); path.moveTo(width / 2, height / 4); path.cubicTo((width * 6) / 7, height / 9, (width * 12) / 13, (height * 2) / 5, width / 2, (height * 7) / 12); canvas.drawPath(path, paint); //右半面 Path path2 = new Path(); path2.moveTo(width / 2, height / 4); path2.cubicTo(width / 7, height / 9, width / 13, (height * 2) / 5, width / 2, (height * 7) / 12); canvas.drawPath(path2, paint); } }
在布局中引入一下
<com.xxb.cache.weight.HeartView android:layout_width="match_parent" android:layout_height="match_parent" />
实现效果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章
Android Activity启动模式之singleTask实例详解
这篇文章主要介绍了Android Activity启动模式之singleTask,结合实例形式较为详细的分析了singleTask模式的功能、使用方法与相关注意事项,需要的朋友可以参考下2016-01-01Android中用Builder模式自定义Dialog的方法
在任何软件操作系统中,Dialog即对话框都是一种重要的交互模式与信息载体,而Android系统本身的Dialog拥有固定的样式,并且在5.0后采用Material Design设计风格的Dialog美观大气。这篇文章将详细介绍Android中用Builder模式自定义Dialog的方法,有需要的可以参考借鉴。2016-10-10Android编程之绝对布局AbsoluteLayout和相对布局RelativeLayout实例详解
这篇文章主要介绍了Android编程之绝对布局AbsoluteLayout和相对布局RelativeLayout实现方法,结合实例形式详细分析了Android绝对布局AbsoluteLayout和相对布局RelativeLayout的原理与使用技巧,需要的朋友可以参考下2015-12-12
最新评论