麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 系統 > Android > 正文

android使用Path繪制出多邊形

2019-10-21 21:26:08
字體:
來源:轉載
供稿:網友

在講使用path繪制多邊形時,講下Canvas的translate(),rotate()方法的使用,本博客中會使用這方面的知識,先單獨講下,搞懂了這個,下面講path繪制多邊形就簡單的多,我們知道每次我們使用canvas.draw...()繪制什么圖形的時候,都是創建了一個新的圖層,如果不知道圖層是啥意思,就去看下我之前寫的關于canvas基礎,有講這方面的,其實你可以理解成每次新創建了一個activity,然后把這個activity壓入棧中,translate()是畫布平移,其實每次畫布還是同一個畫布,通過paint繪制的圖形都是在這同一個canvas上,但是繪制的內容跟你是否使用了translate()有關系,下面通過簡單的demo來演示下:

package smart.com.pathview;import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.util.AttributeSet;import android.view.View;/** * 繪制多邊形 */public class PathmMultiView extends View { private Paint paint; public PathmMultiView(Context context) {  this(context,null); } public PathmMultiView(Context context, AttributeSet attrs) {  this(context, attrs,0); } public PathmMultiView(Context context, AttributeSet attrs, int defStyleAttr) {  super(context, attrs, defStyleAttr);  initPaint(); } private void initPaint() {  paint = new Paint();  paint.setAntiAlias(true);  paint.setStrokeWidth(5);  paint.setTextSize(24); } @Override protected void onDraw(Canvas canvas) {  super.onDraw(canvas);  paint.setColor(Color.GREEN);  canvas.drawText("杭州是個美麗的城市",20,20,paint);  paint.setColor(Color.RED);  canvas.drawPoint(100,100,paint);  canvas.translate(100,100);  paint.setColor(Color.BLUE);  canvas.drawText("杭州是個美麗的城市",0,0,paint); }}

效果:

android,Path,多邊形

上面的紅點是坐標點(100,100)的位置,為什么繪制的藍色的文字是在坐標點(100,100)的位置呢?是因為你canvas使用了translate(100,100)也就是x,y坐標都平移了100px,這個是根據你當前的view的左上角坐標為原點進行平移的,平移肯定是相對那個點進行平移的,不人為的去設置畫布的顏色,默認都是透明的,否則你draw...2次,上次繪制的內容就被覆蓋了,文字太蒼白無力,就好像你對一個女孩說一千篇我愛你,還不如說你在杭州買了套房來的實際,就好像香港有一個電影中的臺詞是這么說的,這是一個最好的時代,也是一個最壞的時代,好了廢話不多說,圖,我要圖!

android,Path,多邊形

關于如何恢復畫布有三種情況 就以平移例子來講

第一種:

你x,y平移了多少后,我們知道x>0是向右平移,x<0是向左平移,那么恢復就很簡單了

canvas.translate(-x,-y)

@Overrideprotected void onDraw(Canvas canvas) { super.onDraw(canvas); paint.setColor(Color.GREEN); canvas.drawText("杭州是個美麗的城市",20,20,paint); paint.setColor(Color.RED); canvas.drawPoint(100,100,paint); canvas.translate(100,100); paint.setColor(Color.BLUE); canvas.translate(-100,-100); canvas.drawText("杭州是個美麗的城市",20,20,paint);}

效果:

android,Path,多邊形

你會發現綠色和藍色是重疊了。

第二種:

配套使用canvas.save() canvas.restore() ;save()是綁定畫布,restore()是讓畫布恢復到最初的狀態

@Overrideprotected void onDraw(Canvas canvas) { super.onDraw(canvas); paint.setColor(Color.GREEN); canvas.save(); canvas.drawText("杭州是個美麗的城市",20,20,paint); paint.setColor(Color.RED); canvas.drawPoint(100,100,paint); canvas.translate(100,100); paint.setColor(Color.BLUE); canvas.restore(); canvas.drawText("杭州是個美麗的城市",20,20,paint);}

效果:

android,Path,多邊形

第三種:

int count = canvas.save(Canvas.MATRIX_SAVE_FLAG);//這個看你是在canvas.draw...哪里調用了,就相當于保存畫布canvas.restoreToCount(count);//恢復

畫圖:

android,Path,多邊形

現在講下畫多邊形,先確定下思路:

1:把這個多邊形的外切圓畫出來當做一個輔助的參考目標,

2:計算多個點的坐標然后連接成一條線

如圖分析:

android,Path,多邊形

現在根據這個思路把代碼實現下:

代碼如下:

package smart.com.pathview;import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.graphics.Path;import android.util.AttributeSet;import android.view.View;/** * 繪制多邊形 */public class PathmMultiView extends View { private Paint paint; private Path path; private int width,height; public PathmMultiView(Context context) {  this(context,null); } public PathmMultiView(Context context, AttributeSet attrs) {  this(context, attrs,0); } public PathmMultiView(Context context, AttributeSet attrs, int defStyleAttr) {  super(context, attrs, defStyleAttr);  initPaint(); } private void initPaint() {  width = 400;  height = 400;  path = new Path();  paint = new Paint();  paint.setAntiAlias(true);  paint.setStrokeWidth(5);  paint.setColor(Color.BLUE);  paint.setStyle(Paint.Style.STROKE); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {  setMeasuredDimension(width,height); } @Override protected void onDraw(Canvas canvas) {  super.onDraw(canvas);  drawMultShape(canvas,6,width/2); } /**  * @param canvas 畫布  * @param count 繪制幾邊形  * @param radius //外圓的半徑  */ public void drawMultShape(Canvas canvas,int count,float radius){  canvas.translate(radius,radius);//  if(count<5){   return;  }  for (int i=0;i<count;i++){   if (i==0){    path.moveTo(radius*cos(360/count*i),radius*sin(360/count*i));//繪制起點   }else{    path.lineTo(radius*cos(360/count*i),radius*sin(360/count*i));   }  }  paint.setStrokeWidth(3);  path.close();  paint.setColor(Color.GREEN);  canvas.drawPath(path,paint);  //因為我下面不再繪制內容了 所以畫布就不恢復了 } float sin(int num){  return (float) Math.sin(num*Math.PI/180); } float cos(int num){  return (float) Math.cos(num*Math.PI/180); }}

效果:

android,Path,多邊形

哪繪制正8變形呢?好說,直接
drawMultShape(canvas,6,width/2); 第二個參數就是幾邊形的改為8就ok了,試試看看效果:

android,Path,多邊形

就一句話,哦了。

還有一個問題就是如果所繪制的是多邊形,但是好像形狀不一樣,怎么修改,這個時候只要旋轉畫布就行了,比如這張圖片:

android,Path,多邊形

使用canvas.rotate(30);旋轉30度后是這樣的

android,Path,多邊形

當然你要在繪制這個圖形之前對畫布進行旋轉,不然不起作用,網上有些五角星的效果,是怎么實現的呢?比如這樣的效果:

android,Path,多邊形

這是正6變形所形成的星星形狀,分析如圖:

android,Path,多邊形

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美一级高清免费 | 久久精品亚洲欧美日韩精品中文字幕 | 精品国产96亚洲一区二区三区 | 看片一区二区三区 | 日韩精品二区 | 黄色免费影片 | 国产免费观看视频 | 香蕉视频1024 | 永久在线观看电影 | 亚洲爱爱网站 | 成人毛片视频免费 | 国产精品99久久久久久久女警 | 国产亚洲精品久久午夜玫瑰园 | 久久精品爱| 久久精品亚洲精品国产欧美kt∨ | 国产福利不卡一区二区三区 | 天海翼四虎精品正在播放 | 美女视频黄视大全视频免费网址 | 毛片免费看的 | 国产一区二区视频精品 | 九九视频在线观看6 | 久久久一区二区三区精品 | 人人舔人人插 | 91精品国产777在线观看 | www国产成人免费观看视频,深夜成人网 | 成人毛片100部 | 99re久久最新地址获取 | 成人aaaaa片毛片按摩 | 国产在线欧美日韩 | 久久久激情网 | 黄色大片在线免费观看 | 精品久久久久久亚洲精品 | 99精品在线观看 | 日本一区二区免费在线观看 | 成人在线激情视频 | 久久久久久久久久美女 | 欧洲精品视频在线观看 | 黄色美女免费 | 视频一区 在线 | 精品国产欧美一区二区 | 国产正在播放 |