本篇文章記錄了一些覺得還是很有意思的一些方法,文章底部有自定義View的干貨推薦哦!
Canvas畫路徑
初始化畫筆工具
mPaint.setColor(Color.RED);//設置畫筆的顏色
mPaint.setStyle(Paint.Style.STROKE);
mPaint.setStrokeWidth(4);//設置畫筆寬度
mPaint.setAntiAlias(true);
畫線(三角形)
Path path = new Path();
path.moveTo(100,100);//設置起始點
path.lineTo(100,300);//第一天直線的終點,也是第二條直線的起點
path.lineTo(500,100);//畫第二條直線
path.close();//閉環(huán)
canvas.drawPath(path,mPaint);
矩形路徑
//第一個逆向生成
Path CCWRectpath = new Path();
RectF rectF1 = new RectF(50,120,340,200);
CCWRectpath.addRect(rectF1, Path.Direction.CCW);
//第二個順向生成
Path CWRectpath = new Path();
RectF rectF2 = new RectF(390,120,680,200);
CWRectpath.addRect(rectF2, Path.Direction.CW);
//畫出路徑
canvas.drawPath(CCWRectpath,mPaint);
canvas.drawPath(CWRectpath,mPaint);
jx.png
好像并沒有什么區(qū)別-_-||
繼續(xù)柒竞,依據(jù)路徑寫出文字
//依據(jù)路徑寫出文字
String text = "風蕭蕭兮易水寒,壯士一去兮不復還";
mPaint.setColor(Color.BLUE);
mPaint.setTextSize(35);
canvas.drawTextOnPath(text,CCWRectpath,0,18,mPaint);//逆時針生成
canvas.drawTextOnPath(text,CWRectpath,0,18,mPaint);//順時針生成
path2.png
看出差別了么(^^)
Direction.CCW 逆時針生成
Direction.CW 順時針生成
圓角矩形路徑
//圓角矩形路徑
mPaint.setColor(Color.RED);
RectF rectF3 = new RectF(50,250,240,400);
//float rx:所產(chǎn)生圓角的橢圓的橫軸半徑政供;
//float ry:所產(chǎn)生圓角的橢圓的縱軸半徑;
path.addRoundRect(rectF3,10,10, Path.Direction.CCW);
RectF rectF4 = new RectF(290,250,480,400);
/*
float[] radii:必須傳入8個數(shù)值,分四組鲫骗,分別對應每個角所使用的橢圓的橫軸半徑和縱軸半徑犬耻,
如{x1,y1,x2,y2,x3,y3,x4,y4},其中执泰,x1,y1對應第一個角的(左上角)用來產(chǎn)生圓角的橢圓的
橫軸半徑和縱軸半徑枕磁,其它類推…
*/
float radii[] ={10,15,20,25,30,35,40,45};
path.addRoundRect(rectF4,radii, Path.Direction.CCW);
canvas.drawPath(path,mPaint);
path3.png
圓、弧的路徑
/**
參數(shù)說明:
float x:圓心X軸坐標
float y:圓心Y軸坐標
float radius:圓半徑
*/
path.addCircle(500,600,100, Path.Direction.CCW);
canvas.drawPath(path,mPaint);
//橢圓的路徑
RectF rectF5 = new RectF(100,500,250,650);
path.addOval(rectF5, Path.Direction.CCW);
canvas.drawPath(path,mPaint);
//6 弧形路徑
RectF rectF6 = new RectF(150,500,350,650);
/*
RectF oval:弧是橢圓的一部分术吝,這個參數(shù)就是生成橢圓所對應的矩形计济;
float startAngle:開始的角度,X軸正方向為0度
float sweepAngel:持續(xù)的度數(shù)排苍;
*/
path.addArc(rectF6,0,100);
canvas.drawPath(path,mPaint);
path4.png
Paint的DrawText方法
Paint的屬性:
//普通設置
paint.setStrokeWidth(6);//設置畫筆寬度
paint.setAntiAlias(true);//指定是否使用抗鋸齒功能,如果使用會使繪圖變慢
paint.setStyle(Paint.Style.FILL);//繪圖樣式,
paint.setTextAlign(Paint.Align.CENTER);//設置文字對齊方式,取值:align.CENTER沦寂、align.LEFT或align.RIGHT
paint.setTextSize(12);//設置文字大小
//樣式設置
paint.setFakeBoldText(true);//設置字體為粗體
paint.setUnderlineText(true);//設置下劃線
paint.setTextScaleX((float) -0.25);//設置字體水平傾斜度,普通斜體字是-0.25
paint.setStrikeThruText(true);//設置帶有刪除線效果
//其他設置
paint.setTextScaleX(2);//只會講水平方向拉伸,高度不會變
區(qū)別
mPaint.setColor(Color.RED);
mPaint.setStrokeWidth(5);
mPaint.setAntiAlias(true);
mPaint.setTextSize(80);
//繪圖樣式的區(qū)別 填充
mPaint.setStyle(Paint.Style.FILL);
canvas.drawText("自律給我自由",100,100,mPaint);
//描邊
mPaint.setStyle(Paint.Style.STROKE);
canvas.drawText("自律給我自由",100,200,mPaint);
//填充且描邊
mPaint.setStyle(Paint.Style.FILL_AND_STROKE);
canvas.drawText("自律給我自由",100,300,mPaint);
//繪圖樣式的區(qū)別 填充
mPaint.setStyle(Paint.Style.FILL);
//設置字體水平傾斜度,普通傾斜字是-0.25,往右斜
mPaint.setTextSkewX((float) -0.25);
canvas.drawText("自律給我自由",100,400,mPaint);
//水平傾斜度設置為:0.25淘衙,往左斜
mPaint.setTextSkewX((float) 0.25);
canvas.drawText("自律給我自由",100,500,mPaint);
//水平拉伸設置
mPaint.setTextSkewX(0);
canvas.drawText("自律給我自由",100,600,mPaint);
//水平方向拉伸兩倍
mPaint.setTextScaleX(2);//水平方向拉伸
canvas.drawText("自律給我自由",100,700,mPaint);
text.png
最后在把最近學習自定義搜集到的覺得還不錯的資料也整理一下吧:
安卓學習筆記
扔物線掘金主頁
啟航的自定義View三部曲