Android自定義View之Canvas的Path方法和Paint的DrawText的方法

本篇文章記錄了一些覺得還是很有意思的一些方法,文章底部有自定義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三部曲

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末传藏,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子彤守,更是在濱河造成了極大的恐慌毯侦,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,681評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件具垫,死亡現(xiàn)場離奇詭異侈离,居然都是意外死亡,警方通過查閱死者的電腦和手機筝蚕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,205評論 3 399
  • 文/潘曉璐 我一進店門卦碾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人起宽,你說我怎么就攤上這事洲胖。” “怎么了坯沪?”我有些...
    開封第一講書人閱讀 169,421評論 0 362
  • 文/不壞的土叔 我叫張陵宾濒,是天一觀的道長。 經(jīng)常有香客問我屏箍,道長,這世上最難降的妖魔是什么橘忱? 我笑而不...
    開封第一講書人閱讀 60,114評論 1 300
  • 正文 為了忘掉前任赴魁,我火速辦了婚禮,結(jié)果婚禮上钝诚,老公的妹妹穿的比我還像新娘颖御。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 69,116評論 6 398
  • 文/花漫 我一把揭開白布潘拱。 她就那樣靜靜地躺著疹鳄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪芦岂。 梳的紋絲不亂的頭發(fā)上瘪弓,一...
    開封第一講書人閱讀 52,713評論 1 312
  • 那天,我揣著相機與錄音禽最,去河邊找鬼腺怯。 笑死,一個胖子當著我的面吹牛川无,可吹牛的內(nèi)容都是我干的呛占。 我是一名探鬼主播,決...
    沈念sama閱讀 41,170評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼懦趋,長吁一口氣:“原來是場噩夢啊……” “哼晾虑!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起仅叫,我...
    開封第一講書人閱讀 40,116評論 0 277
  • 序言:老撾萬榮一對情侶失蹤帜篇,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后惑芭,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體坠狡,經(jīng)...
    沈念sama閱讀 46,651評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,714評論 3 342
  • 正文 我和宋清朗相戀三年遂跟,在試婚紗的時候發(fā)現(xiàn)自己被綠了逃沿。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,865評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡幻锁,死狀恐怖凯亮,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情哄尔,我是刑警寧澤假消,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站岭接,受9級特大地震影響富拗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鸣戴,卻給世界環(huán)境...
    茶點故事閱讀 42,211評論 3 336
  • 文/蒙蒙 一啃沪、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧窄锅,春花似錦创千、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,699評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽械哟。三九已至,卻和暖如春殿雪,著一層夾襖步出監(jiān)牢的瞬間暇咆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,814評論 1 274
  • 我被黑心中介騙來泰國打工冠摄, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留糯崎,地道東北人。 一個月前我還...
    沈念sama閱讀 49,299評論 3 379
  • 正文 我出身青樓河泳,卻偏偏與公主長得像沃呢,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子拆挥,可洞房花燭夜當晚...
    茶點故事閱讀 45,870評論 2 361

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,328評論 25 707
  • 系列文章之 Android中自定義View(一)系列文章之 Android中自定義View(二)系列文章之 And...
    YoungerDev閱讀 4,407評論 3 11
  • 一薄霜、概述 1. 四線格與基線 小時候,我們在剛開始學習寫字母時纸兔,用的本子是四線格的惰瓜,我們必須把字母按照規(guī)則寫在四線...
    addapp閱讀 7,675評論 2 17
  • 剛回到家,葉卿的母親就打來電話汉矿∑榉唬“明天你必須去相親,對方是你張阿姨介紹的洲拇,據(jù)說長的不錯奈揍,個子也高,好像是個公司總監(jiān)...
    葉青辭閱讀 387評論 0 0
  • 關于整理這個話題赋续,我有好多話要說男翰,昨天周六,我在家整理了一上午房間纽乱,整理出不需要的東西(就是這輩子都不會再用...
    Miss墨菲閱讀 166評論 0 0