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

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

概述本文实例讲述了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)

@OverrIDeprotected 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,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,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,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程序设计有所帮助。

总结

以上是内存溢出为你收集整理的Android编程基于自定义view实现公章效果示例【附源码下载】全部内容,希望文章能够帮你解决Android编程基于自定义view实现公章效果示例【附源码下载】所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1143599.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存