Android编程基于自定义view实现公章效果示例【附源码下载】

本文实例讲述了Android编程基于自定义view实现公章效果。分享给大家供大家参考,具体如下:

上次去一个公司面试,面试官问了一个题,怎么用android的自定义view实现一个公章的效果,据说这是华为之前的面试题,我想了下,要是公章的效果,最外层是一个圆,里面是一个五角星,但是这文字怎么画呢,比较难搞,后来回来看了下java的api,发现人家的Path里面本来就提供了这么一个方法:

public void addArc(RectF oval, float startAngle, float sweepAngle) {
 addArc(oval.left, oval.top, oval.right, oval.bottom, startAngle, sweepAngle);
}

然后人家解释说了,根据狐线的角度生成相应的路径,所以我们就可以给文字设置一个相应绘制区域,使其绘制的文字都在这个区域内,

path.addArc(oval,-(firstrad-textPadding*i/2), textPadding);

接下来我们只需要在这个区域内把文字绘制上去就行了。

好的,下面是全部代码:

首先继承自View,我们在构造里面初始化,同样为了方便程序的扩展性,我们用自定义属性,

<declare-styleable name="Seal">
 <attr name="scale_text_size" format="dimension" />
 <attr name="scale_text_color" format="color" />
 <attr name="scale_text" format="string" />
 <attr name="scale_text_padding" format="float" />
 <attr name="circle_stroke_width" format="dimension" />
 <attr name="circle_color" format="color" />
 <attr name="circle_radius" format="dimension" />
</declare-styleable>

然后我们初始化的时候主要初始化文字,文字大小,文字间距,文字颜色等等,

private void initViews(AttributeSet attrs, int defStyle) {
 TypedArray typedArray = getContext().obtainStyledAttributes(attrs, R.styleable.Seal, defStyle, 0);
 circleText = typedArray.getString(R.styleable.Seal_scale_text);
 textSize = typedArray.getDimension(R.styleable.Seal_scale_text_size, 20);
 scaleTextColor = typedArray.getColor(R.styleable.Seal_scale_text_color, getResources().getColor(R.color.c9));
 textPadding=typedArray.getFloat(R.styleable.Seal_scale_text_padding,50);
 circleStrokeWidth = typedArray.getDimensionPixelSize(R.styleable.Seal_circle_stroke_width, 3);
 circleColor = typedArray.getColor(R.styleable.Seal_circle_color, getResources().getColor(R.color.c9));
 circleRadius = typedArray.getDimensionPixelSize(R.styleable.Seal_circle_radius, 7);
 typedArray.recycle();
}

接下来我们在重写Ondraww(Canvas canvas)

@Override
protected void onDraw(Canvas rootCanvas) {
 super.onDraw(rootCanvas);
 Bitmap image = Bitmap.createBitmap(getWidth(), getHeight(), Bitmap.Config.ARGB_8888);
 Canvas canvas = new Canvas(image);
 Paint paint=new Paint();
 drawRing(canvas,paint);
 drawStar(canvas);
 drawText(canvas);
 rootCanvas.drawBitmap(image, 0, 0, null);
}

接下来是对应的三个方法:画圆环(ring),五角星(star),文字(text)

//圆环
private void drawRing(Canvas canvas, Paint paint) {
 centre = canvas.getWidth() / 2; // 获取圆心的x坐标
 radius = (int) (centre - circleStrokeWidth / 2); // 圆环的半径
 paint.setColor(Color.RED); // 设置圆环的颜色
 paint.setStyle(Paint.Style.STROKE); // 设置空心
 paint.setStrokeWidth(circleStrokeWidth); // 设置圆环的宽度
 paint.setAntiAlias(true); // 消除锯齿
 canvas.drawCircle(centre, centre, radius, paint); // 画出圆环
}
//绘制五角星
private void drawStar(Canvas canvas){
 float start_radius = (float) ((radius / 2)*1.1);
 int x = centre, y = centre;
 float x1,y1,x2,y2,x3,y3,x4,y4,x5,y5;
 float r72 = (float) Math.toRadians(72);
 float r36 = (float) Math.toRadians(36);
 //顶点
 x1 = x;
 y1 = y - start_radius;
 //左1
 x2 = (float) (x - start_radius*Math.sin(r72));
 y2 = (float) (y - start_radius*Math.cos(r72));
 //右1
 x3 = (float) (x + start_radius*Math.sin(r72));
 y3 = (float) (y - start_radius*Math.cos(r72));
 //左2
 x4 = (float) (x - start_radius*Math.sin(r36));
 y4 = (float) (y + start_radius*Math.cos(r36));
 //右2
 x5 = (float) (x + start_radius*Math.sin(r36));
 y5 = (float) (y + start_radius*Math.cos(r36));
 //连接各个节点,绘制五角星
 Path path = new Path();
 path.moveTo(x1, y1);
 path.lineTo(x5, y5);
 path.lineTo(x2, y2);
 path.lineTo(x3, y3);
 path.lineTo(x4, y4);
 path.close();
 Paint paint = new Paint();
 paint.setColor(Color.RED);
 canvas.drawPath(path, paint);
}
//文字
private void drawText(Canvas canvas){
 Paint paint = new Paint();
 paint.setColor(Color.RED);
 paint.setTypeface(Typeface.DEFAULT_BOLD);
 paint.setTextAlign(Paint.Align.CENTER);
 paint.setTextSize(radius/5+5);
 //圆弧文字所在矩形范围
 RectF oval=new RectF(0, 0, 2*radius, (float) (2*radius));
 //第一个文字偏移角度,其中padding/2为文字间距
 float firstrad = 90 + textPadding * (circleText.length()) / 4 - textPadding/8;
 for(int i = 0; i < circleText.length(); i++){
  Path path = new Path();
  //根据角度生成弧线路径
  path.addArc(oval,-(firstrad-textPadding*i/2), textPadding);
  canvas.drawTextOnPath(String.valueOf(circleText.charAt(i)), path, -(float) (radius/3),(float) (radius/3), paint);
 }
}

最后在我们需要的视图中引用下就好了

<com.xzh.sealmaster.view.SealView
 android:layout_width="200dp"
 android:layout_height="200dp"
 android:layout_gravity="center"
 app:scale_text_size="16sp"
 app:scale_text_padding="50"
 app:scale_text="华为上海有限公司"
 />

完整实例代码点击此处本站下载

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android图形与图像处理技巧总结》、《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

(0)

相关推荐

  • 最近较流行的效果 Android自定义View实现倾斜列表/图片

    先看看效果图: 实现思路:擦除图片相应的角,然后层叠图片,产生倾斜效果 代码实现: 1.定义属性 在values文件夹下的attrs文件添加以下代码 <resources> <declare-styleable name="TiltView"> <attr name="type" format="integer" /> </declare-styleable> </resources>

  • Android自定义View之酷炫数字圆环

    先看下最终的效果 一.开始实现 新建一个DoughnutView继承View public class DoughnutView extends View { } 先重写onMeasure方法. /** * 当布局为wrap_content时设置默认长宽 * * @param widthMeasureSpec * @param heightMeasureSpec */ @Override protected void onMeasure(int widthMeasureSpec, int hei

  • Android自定义View系列之Path绘制仿支付宝支付成功动画

    前言 使用支付宝付款时,我们可以看到成功或者失败都会有个动画提示,如果我们需要做这样的效果的话,当然,你可以让设计师给你做个GIF,但是我们知道图像比较耗内存的,我们自己可以用代码实现还是代码实现好点吧. 效果 实现方法 首先我们需要了解PathMeasure这个类,这个类我们可以理解为用来管理Path.我们主要看几个方法. PathMeasure(): 构造方法 ,实例化一个对象 PathMeasure(Path path,boolean isClosed):传入Path对象和是否闭合,pat

  • Android自定义View之酷炫圆环(二)

    先看下最终的效果 静态: 动态: 一.开始实现 新建一个DoughnutProgress继承View public class DoughnutProgress extends View { } 先给出一些常量.变量以及公共方法的代码,方便理解后面的代码 private static final int DEFAULT_MIN_WIDTH = 400; //View默认最小宽度 private static final int RED = 230, GREEN = 85, BLUE = 35;

  • Android仿360悬浮小球自定义view实现示例

    Android仿360悬浮小球自定义view实现示例 效果图如下: 实现当前这种类似的效果 和360小球 悬浮桌面差不错类似.这种效果是如何实现的呢.废话不多说 ,直接上代码. 1.新建工程,添加悬浮窗权限. <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /> 2.自定义一个FloatMessagerMainWindow import android.content.Contex

  • Android自定义View实现竖直跑马灯效果案例解析

    首先给出跑马灯效果图 中间的色块是因为视频转成GIF造成的失真,自动忽略哈. 大家知道,横向的跑马灯android自带的TextView就可以实现,详情请百度[Android跑马灯效果].但是竖直的跑马灯效果原生Android是不支持的.网上也有很多网友实现了自定义的效果,但是我一贯是不喜欢看别人的代码,所以这篇博客的思路完全是我自己的想法哈. 首先,我们需要给自定义的控件梳理一下格局,如下图所示: 1.首先我们将控件分为三个区块,上面绿色部分为消失不可见的块,中间黑色部分为可见区域,下面红色部

  • Android自定义View制作仪表盘界面

    前言 最近我跟自定义View杠上了,甚至说有点上瘾到走火入魔了.身为菜鸟的我自然要查阅大量的资料,学习大神们的代码,这不,前两天正好在郭神在微信公众号里推送一片自定义控件的文章--一步步实现精美的钟表界面.正适合我这种菜鸟来学习,闲着没事,我就差不多依葫芦画瓢也写了一个自定义表盘View,现在纯粹最为笔记记录下来.先展示下效果图: 下面进入正题 自定义表盘属性 老规矩,先在attrs文件里添加表盘自定义属性 <declare-styleable name="WatchView"&

  • Android自定义View之继承TextView绘制背景

    本文实例为大家分享了TextView绘制背景的方法,供大家参考,具体内容如下 效果: 实现流程: 1.初始化:对画笔进行设置 mPaintIn = new Paint(); mPaintIn.setAntiAlias(true); mPaintIn.setDither(true); mPaintIn.setStyle(Paint.Style.FILL); mPaintIn.setColor(getResources().getColor(R.color.colorPrimary)); mPain

  • Android自定义view制作绚丽的验证码

    废话不多说了,先给大家展示下自定义view效果图,如果大家觉得还不错的话,请继续往下阅读. 怎么样,这种验证码是不是很常见呢,下面我们就自己动手实现这种效果,自己动手,丰衣足食,哈哈~ 一. 自定义view的步骤 自定义view一直被认为android进阶通向高手的必经之路,其实自定义view好简单,自定义view真正难的是如何绘制出高难度的图形,这需要有好的数学功底(后悔没有好好学数学了~),因为绘制图形经常要计算坐标点及类似的几何变换等等.自定义view通常只需要以下几个步骤: 写一个类继承

  • Android自定义view实现阻尼效果的加载动画

    效果: 需要知识: 1. 二次贝塞尔曲线 2. 动画知识 3. 基础自定义view知识 先来解释下什么叫阻尼运动 阻尼振动是指,由于振动系统受到摩擦和介质阻力或其他能耗而使振幅随时间逐渐衰减的振动,又称减幅振动.衰减振动.[1] 不论是弹簧振子还是单摆由于外界的摩擦和介质阻力总是存在,在振动过程中要不断克服外界阻力做功,消耗能量,振幅就会逐渐减小,经过一段时间,振动就会完全停下来.这种振幅随时间减小的振动称为阻尼振动.因为振幅与振动的能量有关,阻尼振动也就是能量不断减少的振动.阻尼振动是非简谐运

  • Android自定义View实现折线图效果

    下面就是结果图(每种状态用一个表情图片表示): 一.主页面的布局文件如下: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height=&quo

随机推荐