JPEGTranscoder transcoder = new JPEGTranscoder();
String urlPath = "D:/CRD_Material/Scheme/scheme-2.svg";
String s1 = "<svg width='350' height='450' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'>"
+ "<!-- Created with SVG-edit - http://svg-edit.googlecode.com/ --> "
+ "<g><title>Layer 1</title> "
+ " <rect fill='none' stroke='#000000' stroke-width='2' stroke-linejoin='none' stroke-linecap='none' x='18' y='23' width='213' height='352' id='svg_6'/>"
+ " <line fill='none' stroke='#000000' stroke-width='2' stroke-linejoin='none' stroke-linecap='none' x1='17' y1='336' x2='230' y2='336' id='svg_7'/>"
+ " <line fill='none' stroke='#000000' stroke-width='2' stroke-linejoin='none' stroke-linecap='none' x1='20' y1='58' x2='231' y2='58' id='svg_8' stroke-dasharray='2,2'/>"
+ " <rect id='svg_3' height='65' width='181' y='74' x='31' stroke-width='2' stroke='#000000' fill='#0'/> </g> </svg>";
FileWriter writer = new FileWriter("D:/PDFBox/test.svg");
writer.write(s1);
writer.close();
transcoder.addTranscodingHint(JPEGTranscoder.KEY_QUALITY, new Float(1.0));
TranscoderInput input = new TranscoderInput(new FileInputStream("D:/PDFBox/test.svg"));
OutputStream ostream = new FileOutputStream("D:/PDFBox/out.jpg");
TranscoderOutput output = new TranscoderOutput(ostream);
transcoder.transcode(input, output);
ostream.close();
System.exit(0);
This is my code and I want to convert SVG String into JPEG image. While running this code I got the following error:
org.w3c.dom.DOMException: <unknown>:
The attribute "stroke-linecap" represents an invalid CSS value ("none").
Original message:
The "none" identifier is not a valid value for the "stroke-linecap" property
Someone please help me.. Thanks in advance
The only valid values for stroke-linecap
are butt
, round
, and square
, see e.g. here. The default is butt
. So either change none
to one of these, or delete the stroke-linecap='none'
segments everywhere.
Your svg code has also a similar problem with stroke-linejoin
, see valid values here.
And finally fill='#0'
is also incorrect. If you want black, use fill='#000000'
or fill='black'
.
Thus the new string can be
String s1 = "<svg width='350' height='450' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink'>"
+ "<!-- Created with SVG-edit - http://svg-edit.googlecode.com/ --> "
+ "<g><title>Layer 1</title> "
+ " <rect fill='none' stroke='#000000' stroke-width='2' x='18' y='23' width='213' height='352' id='svg_6'/>"
+ " <line fill='none' stroke='#000000' stroke-width='2' x1='17' y1='336' x2='230' y2='336' id='svg_7'/>"
+ " <line fill='none' stroke='#000000' stroke-width='2' x1='20' y1='58' x2='231' y2='58' id='svg_8' stroke-dasharray='2,2'/>"
+ " <rect id='svg_3' height='65' width='181' y='74' x='31' stroke-width='2' stroke='#000000' fill='#000000'/> </g> </svg>";