Android中使用SVG

SVG簡(jiǎn)介

  • SVG 的文件里存儲(chǔ)了繪制圖片的相關(guān)信息霍弹,在要用圖的時(shí)候再把圖畫(huà)出來(lái)肮韧,所以在圖片顯示的時(shí)候會(huì)花費(fèi)更多的時(shí)間消耗更多的資源谓形。
  • SVG 的文件體積遠(yuǎn)小于傳統(tǒng)的位圖文件拟烫,因?yàn)闆](méi)有存儲(chǔ)任何圖像的像素信息宣蔚。
  • SVG的文件畫(huà)出來(lái)的圖像是矢量圖向抢,所以不會(huì)存在失真的問(wèn)題,理論上支持任何級(jí)別的縮放胚委,適應(yīng)性強(qiáng)于傳統(tǒng)的位圖挟鸠。
    CSDN同步發(fā)布

SVG簡(jiǎn)單使用

獲取SVG文件

SVG圖片下載地址
選擇要下載的圖片,下載時(shí)選擇svg下載

svg2android
獎(jiǎng)svg圖片轉(zhuǎn)換成android中的drawable文本

在android上顯示svg圖片

在drawable文件夾中新建文件亩冬,將之前轉(zhuǎn)換后的文本信息復(fù)制到里面

<?xml version="1.0" encoding="utf-8"?>
<vector xmlns:android="http://schemas.android.com/apk/res/android"
    android:width="1024dp"
    android:height="1024dp"
    android:viewportHeight="1024"
    android:viewportWidth="1024">

    <path
        android:fillColor="#1296db"
        android:pathData="M693.403-9.263l-376.691 4.628c-93.005 1.142-141.47 64.931-141.47
121.987v760.555c0 70.909 48.497 147.571 146.098
145.113l367.435-9.257c88.235-2.223 160.61-37.038
160.001-135.856l-4.628-751.298c-0.55-89.394-34.658-137.298-150.745-135.872zM777.275
882.536c0 38.027-35.535 68.978-79.226 68.978h-372.081c-43.673
0-79.207-30.951-79.207-68.978v-755.926h0.018c0-38.043 35.535-68.978
79.207-68.978h372.063c43.673 0 79.226 30.937 79.226 68.978zM737.025
124.46h-450.014c-5.407 0-9.776 3.851-9.776 8.617v669.925c0 4.749 4.369 8.633
9.776 8.633h450.014c5.407 0 9.794-3.867
9.794-8.633v-669.925c0-4.766-4.387-8.617-9.794-8.617zM704.108
766.6l-379.551-4.628-4.628-592.51 379.551 4.628zM512.018 825.994c-32.969
0-62.476 23.634-62.476 52.691 0 29.058 33.092 58.667 72.035 51.497 32.423-5.97
56.768-24.541 56.768-53.583 0-29.058-33.359-50.606-66.327-50.606zM512.018
914.128c-22.191 0-40.231-15.901-40.231-35.443s18.041-35.459 40.231-35.459c22.173
0 50.361 14.874 50.361 34.416 0 19.542-28.188 36.486-50.361 36.486zM447.319
90.589c0-3.515 3.895-6.353 8.702-6.353h111.975c4.805 0 8.684 2.841 8.684 6.353 0
3.514-3.877 13.472-8.684 13.523l-111.975 1.195c-4.788
0.051-8.684-11.205-8.702-14.719z" />
</vector>

布局文件中的imageview直接調(diào)用該文件

  <ImageView
        android:src="@drawable/phone_svg"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

setColorFilter()可改變圖片顏色

        img_phone.setColorFilter(Color.RED);

兼容問(wèn)題

不需要添加任何依賴(lài)包

Gradle在編譯時(shí)會(huì)自動(dòng)生成Vectordrawable對(duì)應(yīng)的位圖資源(如果你支持的最低sdk小于api21, 若大于等于21就不存在兼容性問(wèn)題了)
缺點(diǎn)是同時(shí)打包了位圖與矢量圖資源APK包會(huì)變大. 生成哪種分辨率下的位圖資源可以通過(guò)下面的Gradle配置指定:

defaultConfig { 
      vectorDrawables.generatedDensities = ['hdpi','xxhdpi']
}

使用Support Library 23.2+(不會(huì)自動(dòng)生成位圖)

需要在build.gradle配置文件中增加如下配置:

android { 
     defaultConfig { 
           vectorDrawables.useSupportLibrary = true  
      }
  }

然后在引用Vectordrawable資源時(shí)使用app:srcCompat取代android:src

SVG動(dòng)畫(huà)

網(wǎng)上有個(gè)開(kāi)源庫(kù)PathAnimView

compile 'com.github.mcxtzhang:PathAnimView:V1.0.0'

以下為簡(jiǎn)要流程兄猩,詳情可以去看作者的博客極速get花式Path
1、獲取png圖片
2鉴未、利用vmde將圖片轉(zhuǎn)成svg格式vmde下載地址
3枢冤、將svg圖片進(jìn)行轉(zhuǎn)化Android SVG to VectorDrawable
4、將轉(zhuǎn)化的結(jié)果寫(xiě)到strings中,如下

 <string name="toys">M 3.33 3.52 C 7.15 1.59 12.31 4.86 12.95 9.01 C 15.02 20.49 16.86 32.02 18.84
43.51 C 19.10 45.60 20.73 47.74 23.00 47.70 C 33.34 47.83 43.69 47.73 54.04
47.73 C 55.56 47.81 57.80 47.37 58.39 49.31 C 57.98 50.42 57.23 50.97 56.14
50.98 C 45.42 51.04 34.69 50.98 23.97 51.01 C 20.36 51.33 16.61 48.88 15.90
45.24 C 13.66 33.35 11.97 21.34 9.68 9.46 C 9.18 6.31 5.59 6.39 3.20 5.74 C 3.23
5.18 3.30 4.07 3.33 3.52 Z</string>

5铜秆、布局文件中使用PathAnimView控件

  <com.mcxtzhang.pathanimlib.PathAnimView
        android:id="@+id/pathAnimView1"
        android:layout_width="wrap_content"
        android:layout_height="60dp"
        android:layout_marginTop="260dp"
        android:background="@color/colorAccent"
        android:padding="5dp"/>

6淹真、代碼中加載動(dòng)畫(huà)

        pathAnimView1 = (PathAnimView) findViewById(R.id.pathAnimView1);
        SvgPathParser svgPathParser = new SvgPathParser();
        try {
            Path path = svgPathParser.parsePath(getString(R.string.toys));
            pathAnimView1.setSourcePath(path);
        } catch (ParseException e) {
            e.printStackTrace();
        }
        pathAnimView1.startAnim();

參考文章

SVG 在A(yíng)ndroid中的應(yīng)用
Android Vector曲折的兼容之路
android 中使用svg
Android SVG技術(shù)入門(mén):線(xiàn)條動(dòng)畫(huà)實(shí)現(xiàn)原理

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市连茧,隨后出現(xiàn)的幾起案子核蘸,更是在濱河造成了極大的恐慌,老刑警劉巖啸驯,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件客扎,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡罚斗,警方通過(guò)查閱死者的電腦和手機(jī)徙鱼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)针姿,“玉大人袱吆,你說(shuō)我怎么就攤上這事【嘁” “怎么了绞绒?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)榕暇。 經(jīng)常有香客問(wèn)我蓬衡,道長(zhǎng)喻杈,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任狰晚,我火速辦了婚禮筒饰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘家肯。我一直安慰自己龄砰,他們只是感情好盟猖,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布讨衣。 她就那樣靜靜地躺著,像睡著了一般式镐。 火紅的嫁衣襯著肌膚如雪反镇。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,631評(píng)論 1 305
  • 那天娘汞,我揣著相機(jī)與錄音歹茶,去河邊找鬼。 笑死你弦,一個(gè)胖子當(dāng)著我的面吹牛惊豺,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播禽作,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼尸昧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了旷偿?” 一聲冷哼從身側(cè)響起烹俗,我...
    開(kāi)封第一講書(shū)人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎萍程,沒(méi)想到半個(gè)月后幢妄,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡茫负,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年蕉鸳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片忍法。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡置吓,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出缔赠,到底是詐尸還是另有隱情衍锚,我是刑警寧澤,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布嗤堰,位于F島的核電站戴质,受9級(jí)特大地震影響度宦,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜告匠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一戈抄、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧后专,春花似錦划鸽、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至型凳,卻和暖如春丈冬,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背甘畅。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工埂蕊, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人疏唾。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓蓄氧,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親槐脏。 傳聞我的和親對(duì)象是個(gè)殘疾皇子喉童,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

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