batik1.8相对于1.7的改进
2016-08-02 11:30
369 查看
以前写的java程序用的batik1.7。后来1.8出来了并没有发现什么不同,就一直用1.7了。今天偶然间需要做个图表。使用d3生成了一个柱状图,柱状图的代码如下
<svg contentScriptType="text/ecmascript" width="300.0" xmlns:xlink="http://www.w3.org/1999/xlink" zoomAndPan="magnify" style="background-color:#ffffff;" contentStyleType="text/css" viewBox="0 0 300.0 200.0" height="200.0" preserveAspectRatio="xMidYMid meet" xmlns="http://www.w3.org/2000/svg" version="1.0">
<style>
.axis text {
font: 10px sans-serif;
}
.axis path,
.axis line {
fill: none;
stroke: #000;
shape-rendering: crispEdges;
}
.bar {
fill: steelblue;
fill-opacity: .9;
}
.x.axis path {
display: none;
}
</style>
<g transform="translate(40,20)"><g class="axis" transform="translate(0,150)"><g class="tick" style="opacity: 1;" transform="translate(20,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Ua</text></g><g class="tick" style="opacity: 1;" transform="translate(60,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Ub</text></g><g class="tick" style="opacity: 1;" transform="translate(100,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Uc</text></g><g class="tick" style="opacity: 1;" transform="translate(140,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Uab</text></g><g class="tick" style="opacity: 1;" transform="translate(180,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Uac</text></g><g class="tick" style="opacity: 1;" transform="translate(220,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Ubc</text></g><path class="domain" d="M0,6V0H240V6"></path></g><g class="axis"><g class="tick" style="opacity: 1;" transform="translate(0,150)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">0</text></g><g class="tick" style="opacity: 1;" transform="translate(0,130)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">20</text></g><g class="tick" style="opacity: 1;" transform="translate(0,110.00000000000001)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">40</text></g><g class="tick" style="opacity: 1;" transform="translate(0,90)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">60</text></g><g class="tick" style="opacity: 1;" transform="translate(0,70)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">80</text></g><g class="tick" style="opacity: 1;" transform="translate(0,50.00000000000001)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">100</text></g><g class="tick" style="opacity: 1;" transform="translate(0,29.999999999999993)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">120</text></g><g class="tick" style="opacity: 1;" transform="translate(0,9.999999999999998)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">140</text></g><path class="domain" d="M-6,0H0V150H-6"></path><text transform="rotate(-90)" y="6" dy=".71em" style="text-anchor: end;">kv</text></g><rect class="bar" x="5" width="35" y="30" height="120"></rect><rect class="bar" x="44" width="35" y="50" height="100"></rect><rect class="bar" x="83" width="35" y="20" height="130"></rect><rect class="bar" x="122" width="35" y="60" height="90"></rect><rect class="bar" x="161" width="35" y="70" height="80"></rect><rect class="bar" x="200" width="35" y="0" height="150"></rect></g>
</svg>
可以看到在此文件中应用了style属性。结果用自己的app打开如下图
比较难看,而实际在浏览器下打开如下
发现在自己的app下style并没有生效。试一试的想法替换了batik版本,发现居然一致了。所以估计是batik1.8把这块bug修正了
<svg contentScriptType="text/ecmascript" width="300.0" xmlns:xlink="http://www.w3.org/1999/xlink" zoomAndPan="magnify" style="background-color:#ffffff;" contentStyleType="text/css" viewBox="0 0 300.0 200.0" height="200.0" preserveAspectRatio="xMidYMid meet" xmlns="http://www.w3.org/2000/svg" version="1.0">
<style>
.axis text {
font: 10px sans-serif;
}
.axis path,
.axis line {
fill: none;
stroke: #000;
shape-rendering: crispEdges;
}
.bar {
fill: steelblue;
fill-opacity: .9;
}
.x.axis path {
display: none;
}
</style>
<g transform="translate(40,20)"><g class="axis" transform="translate(0,150)"><g class="tick" style="opacity: 1;" transform="translate(20,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Ua</text></g><g class="tick" style="opacity: 1;" transform="translate(60,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Ub</text></g><g class="tick" style="opacity: 1;" transform="translate(100,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Uc</text></g><g class="tick" style="opacity: 1;" transform="translate(140,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Uab</text></g><g class="tick" style="opacity: 1;" transform="translate(180,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Uac</text></g><g class="tick" style="opacity: 1;" transform="translate(220,0)"><line y2="6" x2="0"></line><text dy=".71em" style="text-anchor: middle;" y="9" x="0">Ubc</text></g><path class="domain" d="M0,6V0H240V6"></path></g><g class="axis"><g class="tick" style="opacity: 1;" transform="translate(0,150)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">0</text></g><g class="tick" style="opacity: 1;" transform="translate(0,130)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">20</text></g><g class="tick" style="opacity: 1;" transform="translate(0,110.00000000000001)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">40</text></g><g class="tick" style="opacity: 1;" transform="translate(0,90)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">60</text></g><g class="tick" style="opacity: 1;" transform="translate(0,70)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">80</text></g><g class="tick" style="opacity: 1;" transform="translate(0,50.00000000000001)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">100</text></g><g class="tick" style="opacity: 1;" transform="translate(0,29.999999999999993)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">120</text></g><g class="tick" style="opacity: 1;" transform="translate(0,9.999999999999998)"><line x2="-6" y2="0"></line><text dy=".32em" style="text-anchor: end;" x="-9" y="0">140</text></g><path class="domain" d="M-6,0H0V150H-6"></path><text transform="rotate(-90)" y="6" dy=".71em" style="text-anchor: end;">kv</text></g><rect class="bar" x="5" width="35" y="30" height="120"></rect><rect class="bar" x="44" width="35" y="50" height="100"></rect><rect class="bar" x="83" width="35" y="20" height="130"></rect><rect class="bar" x="122" width="35" y="60" height="90"></rect><rect class="bar" x="161" width="35" y="70" height="80"></rect><rect class="bar" x="200" width="35" y="0" height="150"></rect></g>
</svg>
可以看到在此文件中应用了style属性。结果用自己的app打开如下图
比较难看,而实际在浏览器下打开如下
发现在自己的app下style并没有生效。试一试的想法替换了batik版本,发现居然一致了。所以估计是batik1.8把这块bug修正了
相关文章推荐
- JavaScript 判断浏览器是否支持SVG的代码
- JavaScript可视化图表库D3.js API中文参考
- 基于jquery和svg实现超炫酷的动画特效
- 推荐10 款 SVG 动画的 JavaScript 库
- 用svg制作富有动态的tooltip
- D3.js中data(), enter() 和 exit()的问题详解
- java生成饼图svg及JFreeChart生成svg图表
- Python实现批量把SVG格式转成png、pdf格式的代码分享
- D3.js数据展现
- Canvas和SVG的区别
- Web开发中的矢量绘图(vml,svg)处理和应用
- SVG 图像入门教程
- 实例讲解使用SVG制作loading加载动画的方法
- ExtJS之Chart导出为png/jpeg,解决中文乱码
- Convert SVG to PDF
- Convert SVG to PDF by using iText in Java(ZT)
- Vector graphics in iText PDF
- GML、SVG、VML的比较
- 路径:path和shape深入了解
- 脸萌~基于SVG绘制