转自:http://www.cnblogs.com/yaowen/p/5660905.html

SVGParserRenderer drawable = new SVGParserRenderer(context, String svgContent);String svgContent = <?xml version="1.0" encoding="utf-8"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg version="1.1" id="图层_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"width="48px" height="48px" viewBox="0 0 48 48" enable-background="new 0 0 48 48" xml:space="preserve">
<path fill="#B0B0B0" d="M3.494,24c0-0.587,0.476-1.063,1.063-1.063h38.886c0.588,0,1.063,0.476,1.063,1.063l0,0c0,0.587-0.475,1.062-1.063,1.062H4.557C3.97,25.063,3.494,24.587,3.494,24L3.494,24z"/>
<g><g><g>
<path fill="#B0B0B0" d="M3.806,23.249c0.415-0.414,1.088-0.414,1.502,0l17.054,17.053c0.415,0.415,0.415,1.087,0,1.503l0,0c-0.415,0.414-1.088,0.414-1.503,0L3.806,24.751C3.391,24.336,3.391,23.665,3.806,23.249L3.806,23.249z"/>
</g><g>
<path fill="#B0B0B0" d="M22.361,6.196c0.415,0.415,0.415,1.087,0,1.502L5.308,24.751c-0.414,0.415-1.087,0.415-1.502,0l0,0c-0.415-0.415-0.415-1.087,0-1.503L20.858,6.196C21.273,5.781,21.946,5.781,22.361,6.196L22.361,6.196z"/>
</g></g></g>
</svg>(SVGView )mSvgView.setSVGRenderer(drawable, null);<com.trevorpage.tpsvg.SVGViewandroid:id="@+id/siv_topicon"android:layout_width="@dimen/abs__shortcut_svg_size"android:layout_height="@dimen/abs__shortcut_svg_size"android:layout_gravity="center">
</com.trevorpage.tpsvg.SVGView>public class SVGView extends View {}
public class SVGParserRenderer extends DefaultHandler {}SVGView.setSVGRenderer(SVGParserRenderer, null);

SVG的解析:

二、SVG的解析

上文提到Android5.0时引入了SVG特性,其中必然会涉及到SVG图片的加载与解析。而svg本质上就是xml文件,所以从解析角度来看,能解析xml文件的工具应该几乎都可以用来解析svg文件。 
1、DOM解析 
查看Android源码可以看出,5.0引入svg后并没有使用dom进行解析svg源文件,虽然svg号称完全支持dom标准。笔者从dom解析的过程可以看出,Dom解析是将xml文件全部载入,组装成一颗dom树,然后通过节点以及节点之间的关系来解析xml文件。虽然一般情况下,svg文件是比较小的,但也不乏有些很复杂的图片会上升到M级别,如果在解析时需要全部载入,对于Android系统来说时比较耗时的,这也许就是dom遭Android淘汰的原因之一吧。 
2、SAX解析 
SAX(Simple API for XML)解析器是一种基于事件的解析器,它的核心是事件处理模式,主要是围绕着事件源以及事件处理器来工作的。当事件源产生事件后,调用事件处理器相应的处理方法,一个事件就可以得到处理。在事件源调用事件处理器中特定方法的时候,还要传递给事件处理器相应事件的状态信息,这样事件处理器才能够根据提供的事件信息来决定自己的行为。SAX解析器的优点是解析速度快,占用内存少。非常适合在Android移动设备中使用 
3、PUll解析 
PULL解析器的运行方式和SAX类似,都是基于事件的模式。不同的是,在PULL解析过程中,我们需要自己获取产生的事件然后做相应的操作,而不像 SAX那样由处理器触发一种事件的方法,执行我们的代码。PULL解析器小巧轻便,解析速度快,简单易用,非常适合在Android移动设备中使 用,Android系统内部在解析各种XML时也是用PULL解析器

三、SVG在Android5.0以上版本中的使用

1、使用方法 
鉴于SVG有那么多的优点,Android于5.0版本将该特性引入。在5.0以上版本中使用方法如下: 
1)获取SVG图片数据 
第一种方法当然是从网上down了(一般直接用来测试使用),这里只给出几个常用素材下载网站: 
http://sc.chinaz.com/ 
http://www.freevectors.net 
http://www.freevectordownload.com/ 
其次就是手工制作了:真正做项目时,方法1肯定满足不了相应的需要了。这时我们只能自己动手来作图了(应该是美工来负责^_^||),相应最常用的软件就是PS、AI或者CDR也可以。具体制作方法这里就不做介绍了,直接上网搜就行。这里给出一个较为详细的例子:http://blog.csdn.net/tianjian4592/article/details/44733123 
2)将普通SVG图片数据转换成Android可用数据 
一般的SVG图片数据是直接在html或jsp中可以使用,Android中若想使用svg则需要中间环节先转换成Vector标签包括的xml文件(如果做动画的话,外面还需要包括一层animated-vector来引用vector资源),其中最重要的就是path元素,该元素就是图片加载显示过程中的绘制轨迹。具体转换方法网上查询得出有两种:一是手动改写,二是直接使用自动转化工具转换(http://inloop.github.io/svg2android/)。具体转换规则以及相应符号意义可以参见:http://www.w3.org/TR/SVG11/paths.html#PathData. 
3)在工程中使用 
svg在5.0以上的Android工程中使用相对较为简单,直接用drawable控件(如mageView等)引用第二步中转换得来的xml文件资源即可。 
2、Demo实例 
实例一:mytest(使用Drawable控件引用5.0新特性vector资源) 
【关键代码摘要】 
使用vector标签包括path元素 
[ sharp_rect.xml ]

<?xml version="1.0" encoding="utf-8"?>
<vector xmlns:android="http://schemas.android.com/apk/res/android" android:width="180dp" android:height="320dp" android:viewportWidth="180" android:viewportHeight="400"> <path  android:name="sharp_rect" android:fillColor="#000000" android:pathData="M 320,180 L 0,320 0,0 180,0 z" /> </vector>

使用ImageView引用vector资源sharp_rect 
[ activity_main.xml ]

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity"> <ImageView android:src="@drawable/sharp_rect" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </RelativeLayout>

Demo附件: mytest.zip 
效果图: 

实例二:【VectorCard】使用5.0新特性animated-vector标签引用xml中的svg path元素 
【关键代码摘要】 
[ to_stop.xml ]

<objectAnimator xmlns:android="http://schemas.android.com/apk/res/android" android:duration="500" android:interpolator="@android:interpolator/decelerate_cubic" android:propertyName="pathData" android:valueType="pathType" android:repeatMode="reverse" android:repeatCount="1" android:valueFrom="M100,100 L400,250 L100,400 L100,400 z" android:valueTo="M100,100 L400,100 L400,400 L100,400 z" />

[ animated_play.xml ]

<?xml version="1.0" encoding="utf-8"?>
<animated-vector xmlns:android="http://schemas.android.com/apk/res/android" android:drawable="@drawable/play_icon"> <target  android:animation="@animator/to_stop" android:name="play" /> </animated-vector>

Demo附件: app.zip 
效果图: 

3、小结 
Android5.0关于这块新特性的添加主要是依赖于Vctor,对应的类为VectorDrawable以及AnimatedVectorDrawable。前者主要用于矢量图的加载,后者主要用于矢量动画的加载。二者在使用过程中要区分对待。

四、Android5.0以下使用SVG探索总结

经过这短时间的不断摸索与实验,按照svg_android组织的方法主要有以下两种: 
1、基于svg_android库 
抽取类似svg_android库中适合5.0以下的,且可以解析svg的Java文件,自定义类似svg的控件,进行Android工程的搭建(该实例使用sax解析svg文件)。 
对应实例:【SVGMapView-master】 
Demo附件: SVGMapView-master.zip 
效果图: 

【说明】 该方法需要开发者自己去重写解析函数,目前该实例并不能支持所有的svg语法的解析,如将该方法布置到项目中,需要大量拓展解析甚至加载SVg的功能函数。 
2、基于JNI技术 
加载及加息svg的工作交给C/C++处理,上层使用java调用对应.so库暴露的接口。 
对应实例:【ImageViewSvg】 
Demo附件: ImageViewSvg.zip 
效果图: 

【说明】该方案虽然使用了JNI技术来加载并解析svg文件,但目前其解析度有限,功能较为单一,如需要布置该方案于项目中,对于jni侧也需要扩展大量的svg解析函数。且需要优化对应的加载处理环节。

五、总结

从整体上看,目前是有可能将svg应用到Android5.0以下版本的。但其的稳定性,以及后续的工作量是需要我们仔细斟酌的问题之一。

Android解析SVG相关推荐

  1. Android 使用svg构造交互式中国地图

    概念 什么是svg 即Scalable Vector Graphics 可伸缩矢量图形 SVG的W3C的解释: http://www.w3school.com.cn/svg/svg_intro.asp ...

  2. Android矢量图动画特效,Android使用SVG矢量图打造酷炫动画效果

    一个真正Android使用SVG矢量图打造酷炫动效往往让人虎躯一震,话不多说,咱们先看看效果: 这个效果我们需要考虑以下几个问题: 1. 这是图片还是文字: 2. 如果是图片该如何拿到图形的边沿线坐标 ...

  3. 【Android】SVG和VectorDrawable——相关格式转换

    SVG是矢量图,刚接触尚不能仔细介绍,但只需记得一点:放大不失真,存储也方便. 因为多数户型图使用SVG格式,Android要用的话必须通过相关转换工具,将原SVG格式文件,转换为XML后缀的Vect ...

  4. Android 解析包出错问题

    2019独角兽企业重金招聘Python工程师标准>>> Android 解析包出错问题 app上线后经常会遇到安装包解析出错问题,今天刚好做个不完整的总结, 解决问题 检测系统是否开 ...

  5. Android解析WindowManagerService(二)WMS的重要成员和Window的添加过程

    前言 在本系列的上一篇文章中,我们学习了WMS的诞生,WMS被创建后,它的重要的成员有哪些?Window添加过程的WMS部分做了什么呢?这篇文章会给你解答. 1.WMS的重要成员 所谓WMS的重要成员 ...

  6. Android 解析AsyncTask(一)

    Android 解析AsyncTask(一) 大家都知道在开发Android中涉及到UI的修改都必须在UI线程中操作,并且执行耗时的操作绝不能在UI线程上干,一般使用线程或者开启线程池处理.如果要把耗 ...

  7. Android解析WindowManagerService(三)Window的删除过程

    相关文章 Android系统启动系列 Android深入四大组件系列 Android应用进程启动过程系列 Android解析WindowManager系列 前言 在本系列文章中,我提到过:Window ...

  8. android wms,Android解析WindowManagerService(一)WMS的诞生

    原标题:Android解析WindowManagerService(一)WMS的诞生 前言 此前我用多篇文章介绍了WindowManager,这个系列我们来介绍WindowManager的管理者WMS ...

  9. android 生成泛型对象,java android解析多层含有泛型对象的json数据获取不到泛型类型解析失败解决办法...

    ####问题描述 * java 解析多层含有泛型对象的json数据获取不到泛型类型 * 如果将泛型改成实际的类型就能正常解析 * 如果不改成实际的类型泛型数据被解析成com.google.gson.i ...

最新文章

  1. java9可执行jar_单个java文件打成可执行jar包
  2. 真的,千万不要给女朋友解释 什么是 “羊群效应”
  3. 基于激光雷达的里程计及3D点云地图中的定位方法
  4. Android开发中完全退出程序的三种方法
  5. API网关Kong系列(二)部署
  6. [Python人工智能] 二.theano实现回归神经网络分析
  7. 使用navicat for mysql 创建外键foreign keys时,总会自动创建索引indexs
  8. 华为开启管理员模式_又一年的心动模式开启,华为nova8系列8号色撩人肺腑
  9. java 读取1m文件_java的FileInputStream类读取文件
  10. 面试题:二叉树中和为某一路径
  11. java 蓝桥杯算法训练 快速排序
  12. wpf判断一个窗体是否运行_算法8 判断一个数是否是回文数
  13. Session过期处理
  14. 好工具推荐系列:Github客户端GitHub Desktop使用方法
  15. 点计算机管理没反应,电脑任务栏没反应怎么办 任务栏没反应解决方法
  16. linux 基础环境安装教程,Linux安装及初始环境设置基础教程
  17. R语言必看推荐:R语言入门经典版(中文版)+R语言实战第二版(中文完整版)
  18. java如何在控制台重定向_R - 控制台输出重定向不能(可靠地)从函数调用中工作...
  19. 云服务器上的项目无法连接数据库,云服务器中项目连接数据库
  20. 给媳妇做一个记录心情的小程序

热门文章

  1. poj 2263 最短路变形——最小边的最大值
  2. np.vstack与np.newaxis的含义
  3. matlab 拉普拉斯锐化函数_机器视觉 03.3 频域高通滤波(锐化)
  4. php简易投票系统设计,如何使用php做出简易在线投票系统
  5. 3_python基础—运算符 1
  6. shell脚本面试题
  7. python中返回上一步操作_通过实例解析Python文件操作实现步骤
  8. linux判断redis是否启动成功_redis的前生后世
  9. 开发浏览器监控网页数据变化_贝程学院:Selenium辅助开发工具Firebug和Firepath
  10. getJPAQueryFactory与getJPAQuery使用