org.apache.batik.svggen.SVGCSSStyler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of batik-svggen Show documentation
Show all versions of batik-svggen Show documentation
Batik Java2D SVG generator
/*
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package org.apache.batik.svggen;
import java.util.List;
import java.util.ArrayList;
import org.w3c.dom.Attr;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
/**
* This utility class converts a standard SVG document that uses
* attribute into one that uses the CSS style attribute instead.
*
* @author Vincent Hardy
* @version $Id: SVGCSSStyler.java 1804130 2017-08-04 14:41:11Z ssteiner $
*/
public class SVGCSSStyler implements SVGSyntax{
private static final char CSS_PROPERTY_VALUE_SEPARATOR = ':';
private static final char CSS_RULE_SEPARATOR = ';';
private static final char SPACE = ' ';
/**
* Invoking this method removes all the styling attributes
* (such as 'fill' or 'fill-opacity') from the input element
* and its descendant and replaces them with their CSS2
* property counterparts.
*
* @param node SVG Node to be converted to use style
*/
public static void style(Node node){
NamedNodeMap attributes = node.getAttributes();
if (attributes != null){
// Has to be an Element, as it has attributes
// According to spec.
Element element = (Element)node;
StringBuffer styleAttrBuffer = new StringBuffer();
int nAttr = attributes.getLength();
List toBeRemoved = new ArrayList();
for(int i=0; i 0){
// There were some styling attributes
// System.out.println("Setting style attribute on node: " + styleAttrBuffer.toString().trim());
element.setAttributeNS(null,
SVG_STYLE_ATTRIBUTE,
styleAttrBuffer.toString().trim());
int n = toBeRemoved.size();
for (Object aToBeRemoved : toBeRemoved) {
element.removeAttribute((String) aToBeRemoved);
}
}
// else
// System.out.println("NO STYLE PROPERTIES");
}
// Now, process child elements
NodeList children = node.getChildNodes();
int nChildren = children.getLength();
for(int i=0; i