国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

Android編程基于自定義view實現公章效果示例【附源碼下載】

2019-12-12 01:37:32
字體:
來源:轉載
供稿:網友

本文實例講述了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, 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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 靖江市| 临夏市| 斗六市| 思茅市| 洮南市| 北辰区| 麦盖提县| 泽普县| 石狮市| 惠水县| 五家渠市| 昔阳县| 高州市| 江津市| 新乡市| 哈尔滨市| 井冈山市| 舒兰市| 霍林郭勒市| 平陆县| 宜宾市| 青龙| 宁都县| 银川市| 温州市| 邹平县| 普兰店市| 郧西县| 桂林市| 兴宁市| 德庆县| 亳州市| 丹东市| 化州市| 河南省| 湟中县| SHOW| 博客| 科技| 扶风县| 鹤庆县|