1SVG(3) User Contributed Perl Documentation SVG(3)
2
3
4
6 SVG - Perl extension for generating Scalable Vector Graphics (SVG)
7 documents.
8
10 #!/usr/bin/perl
11 use strict;
12 use warnings;
13 use SVG;
14
15 # create an SVG object
16 my $svg= SVG->new( width => 200, height => 200);
17
18 # use explicit element constructor to generate a group element
19 my $y = $svg->group(
20 id => 'group_y',
21 style => {
22 stroke => 'red',
23 fill => 'green'
24 },
25 );
26
27 # add a circle to the group
28 $y->circle( cx => 100, cy => 100, r => 50, id => 'circle_in_group_y' );
29
30 # or, use the generic 'tag' method to generate a group element by name
31 my $z = $svg->tag('g',
32 id => 'group_z',
33 style => {
34 stroke => 'rgb(100,200,50)',
35 fill => 'rgb(10,100,150)'
36 }
37 );
38
39 # create and add a circle using the generic 'tag' method
40 $z->tag('circle', cx => 50, cy => 50, r => 100, id => 'circle_in_group_z');
41
42 # create an anchor on a rectangle within a group within the group z
43 my $k = $z->anchor(
44 id => 'anchor_k',
45 -href => 'http://test.hackmare.com/',
46 target => 'new_window_0'
47 )->rectangle(
48 x => 20, y => 50,
49 width => 20, height => 30,
50 rx => 10, ry => 5,
51 id => 'rect_k_in_anchor_k_in_group_z'
52 );
53
54 # now render the SVG object, implicitly use svg namespace
55 print $svg->xmlify;
56
57 # or render a child node of the SVG object without rendering the entire object
58 print $k->xmlify; #renders the anchor $k above containing a rectangle, but does not
59 #render any of the ancestor nodes of $k
60
61
62 # or, explicitly use svg namespace and generate a document with its own DTD
63 print $svg->xmlify(-namespace=>'svg');
64
65 # or, explicitly use svg namespace and generate an inline docunent
66 print $svg->xmlify(
67 -namespace => "svg",
68 -pubid => "-//W3C//DTD SVG 1.0//EN",
69 -inline => 1
70 );
71
72 See the other modules in this distribution: SVG::DOM, SVG::XML,
73 SVG::Element, and SVG::Extension.
74
75 See SVG::Parser for reading SVG files as "SVG" objects.
76
77 Converting SVG to PNG and other raster image formats
78 The convert command of <http://www.imagemagick.org/> (also via
79 Image::Magick ) can convert SVG files to PNG and other formats.
80
81 Image::LibRSVG can convert SVG to other format.
82
84 examples/circle.pl generates the following image:
85
86 <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
87 <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN" "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd">
88 <svg height="200" width="200" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
89 <title >I am a title</title>
90 <g id="group_y" style="fill: green; stroke: red">
91 <circle cx="100" cy="100" id="circle_in_group_y" r="50" />
92 <!-- This is a comment -->
93 </g>
94 </svg>
95
96 That you can either embed directly into HTML or can include it using:
97
98 <object data="file.svg" type="image/svg+xml"></object>
99
100 (The image was converted to png using Image::LibRSVG. See the
101 svg2png.pl script in the examples directory.)
102
103 See also the examples directory in this distribution which contains
104 several fully documented examples.
105
107 SVG is a 100% Perl module which generates a nested data structure
108 containing the DOM representation of an SVG (Scalable Vector Graphics)
109 image. Using SVG, you can generate SVG objects, embed other SVG
110 instances into it, access the DOM object, create and access javascript,
111 and generate SMIL animation content.
112
113 General Steps to generating an SVG document
114 Generating SVG is a simple three step process:
115
116 1 Construct a new SVG object with "new".
117 2 Call element constructors such as "circle" and "path" to create SVG
118 elements.
119 3 Render the SVG object into XML using the "xmlify" method.
120
121 The "xmlify" method takes a number of optional arguments that control
122 how SVG renders the object into XML, and in particular determine
123 whether a standalone SVG document or an inline SVG document fragment is
124 generated:
125
126 -standalone
127 A complete SVG document with its own associated DTD. A namespace for
128 the SVG elements may be optionally specified.
129
130 -inline
131 An inline SVG document fragment with no DTD that is embedded within
132 other XML content. As with standalone documents, an alternate namespace
133 may be specified.
134
135 No XML content is generated until the third step is reached. Up until
136 this point, all constructed element definitions reside in a DOM-like
137 data structure from which they can be accessed and modified.
138
139 EXPORTS
140 None. However, SVG permits both options and additional element methods
141 to be specified in the import list. These options and elements are then
142 available for all SVG instances that are created with the "new"
143 constructor. For example, to change the indent string to two spaces per
144 level:
145
146 use SVG (-indent => " ");
147
148 With the exception of -auto, all options may also be specified to the
149 "new" constructor. The currently supported options and their default
150 value are:
151
152 # processing options
153 -auto => 0, # permit arbitrary autoloading of all unrecognised elements
154 -printerror => 1, # print error messages to STDERR
155 -raiseerror => 1, # die on errors (implies -printerror)
156
157 # rendering options
158 -indent => "\t", # what to indent with
159 -elsep => "\n", # element line (vertical) separator
160 # (note that not all agents ignor trailing blanks)
161 -nocredits => 0, # enable/disable credit note comment
162 -namespace => '', # The root element's (and it's children's) namespace prefix
163
164 # XML and Doctype declarations
165 -inline => 0, # inline or stand alone
166 -docroot => 'svg', # The document's root element
167 -version => '1.0',
168 -extension => '',
169 -encoding => 'UTF-8',
170 -xml_svg => 'http://www.w3.org/2000/svg', # the svg xmlns attribute
171 -xml_xlink => 'http://www.w3.org/1999/xlink', # the svg tag xmlns:xlink attribute
172 -standalone => 'yes',
173 -pubid => "-//W3C//DTD SVG 1.0//EN", # formerly -identifier
174 -sysid => 'http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd', # the system id
175
176 SVG also allows additional element generation methods to be specified
177 in the import list. For example to generate 'star' and 'planet' element
178 methods:
179
180 use SVG qw(star planet);
181
182 or:
183
184 use SVG ("star","planet");
185
186 This will add 'star' to the list of elements supported by SVG.pm (but
187 not of course other SVG parsers...). Alternatively the '-auto' option
188 will allow any unknown method call to generate an element of the same
189 name:
190
191 use SVG (-auto => 1, "star", "planet");
192
193 Any elements specified explicitly (as 'star' and 'planet' are here) are
194 predeclared; other elements are defined as and when they are seen by
195 Perl. Note that enabling '-auto' effectively disables compile-time
196 syntax checking for valid method names.
197
198 use SVG (
199 -auto => 0,
200 -indent => " ",
201 -raiseerror => 0,
202 -printerror => 1,
203 "star", "planet", "moon"
204 );
205
206 Default SVG tag
207 The Default SVG tag will generate the following XML:
208
209 $svg = SVG->new;
210 print $svg->xmlify;
211
212 Resulting XML snippet:
213
214 <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
215 <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN" "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd">
216 <svg height="100%" width="100%" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
217 <!--
218 Generated using the Perl SVG Module V2.50
219 by Ronan Oger
220 -->
221
223 SVG provides both explicit and generic element constructor methods.
224 Explicit generators are generally (with a few exceptions) named for the
225 element they generate. If a tag method is required for a tag containing
226 hyphens, the method name replaces the hyphen with an underscore. ie: to
227 generate tag <column-heading id="new"> you would use method
228 $svg->column_heading(id=>'new').
229
230 All element constructors take a hash of element attributes and options;
231 element attributes such as 'id' or 'border' are passed by name, while
232 options for the method (such as the type of an element that supports
233 multiple alternate forms) are passed preceded by a hyphen, e.g '-type'.
234 Both types may be freely intermixed; see the "fe" method and code
235 examples throughout the documentation for more examples.
236
237 new (constructor)
238 $svg = SVG->new(%attributes)
239
240 Creates a new SVG object. Attributes of the document SVG element be
241 passed as an optional list of key value pairs. Additionally, SVG
242 options (prefixed with a hyphen) may be set on a per object basis:
243
244 my $svg1 = SVG->new;
245
246 my $svg2 = SVG->new(id => 'document_element');
247
248 my $svg3 = SVG->new(
249 -printerror => 1,
250 -raiseerror => 0,
251 -indent => ' ',
252 -docroot => 'svg', #default document root element (SVG specification assumes svg). Defaults to 'svg' if undefined
253 -sysid => 'abc', #optional system identifyer
254 -pubid => "-//W3C//DTD SVG 1.0//EN", #public identifyer default value is "-//W3C//DTD SVG 1.0//EN" if undefined
255 -namespace => 'mysvg',
256 -inline => 1
257 id => 'document_element',
258 width => 300,
259 height => 200,
260 );
261
262 SVG instance represents the document and not the "<svg>" root element.
263
264 Default SVG options may also be set in the import list. See "EXPORTS"
265 above for more on the available options.
266
267 Furthermore, the following options:
268
269 -version
270 -encoding
271 -standalone
272 -namespace Defines the document or element level namespace. The order of assignment priority is element,document .
273 -inline
274 -identifier
275 -nostub
276 -dtd (standalone)
277
278 may also be set in xmlify, overriding any corresponding values set in
279 the SVG->new declaration
280
281 xmlify (alias: to_xml render serialise serialize)
282 $string = $svg->xmlify(%attributes);
283
284 Returns xml representation of svg document.
285
286 XML Declaration
287
288 Name Default Value
289 -version '1.0'
290 -encoding 'UTF-8'
291 -standalone 'yes'
292 -namespace 'svg' - namespace for elements
293 -inline '0' - If '1', then this is an inline document.
294 -pubid '-//W3C//DTD SVG 1.0//EN';
295 -dtd (standalone) 'http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd'
296
297 tag (alias: element)
298 $tag = $svg->tag($name, %attributes)
299
300 Generic element generator. Creates the element named $name with the
301 attributes specified in %attributes. This method is the basis of most
302 of the explicit element generators.
303
304 my $tag = $svg->tag('g', transform=>'rotate(-45)');
305
306 anchor
307 $tag = $svg->anchor(%attributes)
308
309 Generate an anchor element. Anchors are put around objects to make them
310 'live' (i.e. clickable). It therefore requires a drawn object or group
311 element as a child.
312
313 optional anchor attributes
314
315 The following attributes are expected for anchor tags (any any tags
316 which use -href links):
317
318 -href required
319 -type optional
320 -role optional
321 -title optional
322 -show optional
323 -arcrole optional
324 -actuate optional
325 target optional
326 For more information on the options, refer to the w3c XLink
327 specification at <http://www.w3.org/TR/xlink/>
328
329 Example:
330
331 # generate an anchor
332 $tag = $SVG->anchor(
333 -href=>'http://here.com/some/simpler/SVG.SVG'
334 -title => 'new window 2 example title',
335 -actuate => 'onLoad',
336 -show=> 'embed',
337
338 );
339
340 For more information about the options above, refer to Link section in
341 the SVG recommendation: <http://www.w3.org/TR/SVG11/linking.html#Links>
342
343 # add a circle to the anchor. The circle can be clicked on.
344 $tag->circle(cx => 10, cy => 10, r => 1);
345
346 # more complex anchor with both URL and target
347 $tag = $SVG->anchor(
348 -href => 'http://somewhere.org/some/other/page.html',
349 target => 'new_window'
350 );
351
352
353 # generate an anchor
354 $tag = $svg->anchor(
355 -href=>'http://here.com/some/simpler/svg.svg'
356 );
357 # add a circle to the anchor. The circle can be clicked on.
358 $tag->circle(cx => 10, cy => 10, r => 1);
359
360 # more complex anchor with both URL and target
361 $tag = $svg->anchor(
362 -href => 'http://somewhere.org/some/other/page.html',
363 target => 'new_window'
364 );
365
366 circle
367 $tag = $svg->circle(%attributes)
368
369 Draw a circle at (cx,cy) with radius r.
370
371 my $tag = $svg->circle(cx => 4, cy => 2, r => 1);
372
373 ellipse
374 $tag = $svg->ellipse(%attributes)
375
376 Draw an ellipse at (cx,cy) with radii rx,ry.
377
378 use SVG;
379
380 # create an SVG object
381 my $svg= SVG->new( width => 200, height => 200);
382
383 my $tag = $svg->ellipse(
384 cx => 10,
385 cy => 10,
386 rx => 5,
387 ry => 7,
388 id => 'ellipse',
389 style => {
390 'stroke' => 'red',
391 'fill' => 'green',
392 'stroke-width' => '4',
393 'stroke-opacity' => '0.5',
394 'fill-opacity' => '0.2',
395 }
396 );
397
398 See The example/ellipse.pl
399
400 rectangle (alias: rect)
401 $tag = $svg->rectangle(%attributes)
402
403 Draw a rectangle at (x,y) with width 'width' and height 'height' and
404 side radii 'rx' and 'ry'.
405
406 $tag = $svg->rectangle(
407 x => 10,
408 y => 20,
409 width => 4,
410 height => 5,
411 rx => 5.2,
412 ry => 2.4,
413 id => 'rect_1'
414 );
415
416 image
417 $tag = $svg->image(%attributes)
418
419 Draw an image at (x,y) with width 'width' and height 'height' linked to
420 image resource '-href'. See also "use".
421
422 $tag = $svg->image(
423 x => 100,
424 y => 100,
425 width => 300,
426 height => 200,
427 '-href' => "image.png", #may also embed SVG, e.g. "image.svg"
428 id => 'image_1'
429 );
430
431 Output:
432
433 <image xlink:href="image.png" x="100" y="100" width="300" height="200"/>
434
435 use
436 $tag = $svg->use(%attributes)
437
438 Retrieve the content from an entity within an SVG document and apply it
439 at (x,y) with width 'width' and height 'height' linked to image
440 resource '-href'.
441
442 $tag = $svg->use(
443 x => 100,
444 y => 100,
445 width => 300,
446 height => 200,
447 '-href' => "pic.svg#image_1",
448 id => 'image_1'
449 );
450
451 Output:
452
453 <use xlink:href="pic.svg#image_1" x="100" y="100" width="300" height="200"/>
454
455 According to the SVG specification, the 'use' element in SVG can point
456 to a single element within an external SVG file.
457
458 polygon
459 $tag = $svg->polygon(%attributes)
460
461 Draw an n-sided polygon with vertices at points defined by a string of
462 the form 'x1,y1,x2,y2,x3,y3,... xy,yn'. The "get_path" method is
463 provided as a convenience to generate a suitable string from coordinate
464 data.
465
466 # a five-sided polygon
467 my $xv = [0, 2, 4, 5, 1];
468 my $yv = [0, 0, 2, 7, 5];
469
470 my $points = $svg->get_path(
471 x => $xv,
472 y => $yv,
473 -type =>'polygon'
474 );
475
476 my $poly = $svg->polygon(
477 %$points,
478 id => 'pgon1',
479 style => \%polygon_style
480 );
481
482 SEE ALSO:
483
484 "polyline", "path", "get_path".
485
486 polyline
487 $tag = $svg->polyline(%attributes)
488
489 Draw an n-point polyline with points defined by a string of the form
490 'x1,y1,x2,y2,x3,y3,... xy,yn'. The "get_path" method is provided as a
491 convenience to generate a suitable string from coordinate data.
492
493 # a 10-pointsaw-tooth pattern
494 my $xv = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
495 my $yv = [0, 1, 0, 1, 0, 1, 0, 1, 0, 1];
496
497 my $points = $svg->get_path(
498 x => $xv,
499 y => $yv,
500 -type => 'polyline',
501 -closed => 'true' #specify that the polyline is closed.
502 );
503
504 my $tag = $svg->polyline (
505 %$points,
506 id =>'pline_1',
507 style => {
508 'fill-opacity' => 0,
509 'stroke' => 'rgb(250,123,23)'
510 }
511 );
512
513 line
514 $tag = $svg->line(%attributes)
515
516 Draw a straight line between two points (x1,y1) and (x2,y2).
517
518 my $tag = $svg->line(
519 id => 'l1',
520 x1 => 0,
521 y1 => 10,
522 x2 => 10,
523 y2 => 0,
524 );
525
526 To draw multiple connected lines, use "polyline".
527
528 text
529 $text = $svg->text(%attributes)->cdata();
530
531 $text_path = $svg->text(-type=>'path');
532 $text_span = $text_path->text(-type=>'span')->cdata('A');
533 $text_span = $text_path->text(-type=>'span')->cdata('B');
534 $text_span = $text_path->text(-type=>'span')->cdata('C');
535
536 Define the container for a text string to be drawn in the image.
537
538 Input:
539
540 -type = path type (path | polyline | polygon)
541 -type = text element type (path | span | normal [default])
542
543 my $text1 = $svg->text(
544 id => 'l1',
545 x => 10,
546 y => 10
547 )->cdata('hello, world');
548
549 my $text2 = $svg->text(
550 id => 'l1',
551 x => 10,
552 y => 10,
553 -cdata => 'hello, world',
554 );
555
556 my $text = $svg->text(
557 id => 'tp',
558 x => 10,
559 y => 10,
560 -type => path,
561 )
562 ->text(id=>'ts' -type=>'span')
563 ->cdata('hello, world');
564
565 SEE ALSO:
566
567 "desc", "cdata".
568
569 title
570 $tag = $svg->title(%attributes)
571
572 Generate the title of the image.
573
574 my $tag = $svg->title(id=>'document-title')->cdata('This is the title');
575
576 desc
577 $tag = $svg->desc(%attributes)
578
579 Generate the description of the image.
580
581 my $tag = $svg->desc(id=>'document-desc')->cdata('This is a description');
582
583 comment
584 $tag = $svg->comment(@comments)
585
586 Generate the description of the image.
587
588 my $tag = $svg->comment('comment 1','comment 2','comment 3');
589
590 pi (Processing Instruction)
591 $tag = $svg->pi(@pi)
592
593 Generate a set of processing instructions
594
595 my $tag = $svg->pi('instruction one','instruction two','instruction three');
596
597 returns:
598 <lt>?instruction one?<gt>
599 <lt>?instruction two?<gt>
600 <lt>?instruction three?<gt>
601
602 script
603 $tag = $svg->script(%attributes)
604
605 Generate a script container for dynamic (client-side) scripting using
606 ECMAscript, Javascript or other compatible scripting language.
607
608 my $tag = $svg->script(-type=>"text/ecmascript");
609 #or my $tag = $svg->script();
610 #note that type ecmascript is not Mozilla compliant
611
612 # populate the script tag with cdata
613 # be careful to manage the javascript line ends.
614 # Use qq{text} or q{text} as appropriate.
615 # make sure to use the CAPITAL CDATA to poulate the script.
616 $tag->CDATA(qq{
617 function d() {
618 //simple display function
619 for(cnt = 0; cnt < d.length; cnt++)
620 document.write(d[cnt]);//end for loop
621 document.write("<BR>");//write a line break
622 }
623 });
624
625 path
626 $tag = $svg->path(%attributes)
627
628 Draw a path element. The path vertices may be provided as a parameter
629 or calculated using the "get_path" method.
630
631 # a 10-pointsaw-tooth pattern drawn with a path definition
632 my $xv = [0,1,2,3,4,5,6,7,8,9];
633 my $yv = [0,1,0,1,0,1,0,1,0,1];
634
635 $points = $svg->get_path(
636 x => $xv,
637 y => $yv,
638 -type => 'path',
639 -closed => 'true' #specify that the polyline is closed
640 );
641
642 $tag = $svg->path(
643 %$points,
644 id => 'pline_1',
645 style => {
646 'fill-opacity' => 0,
647 'fill' => 'green',
648 'stroke' => 'rgb(250,123,23)'
649 }
650 );
651
652 SEE ALSO: "get_path".
653
654 get_path
655 $path = $svg->get_path(%attributes)
656
657 Returns the text string of points correctly formatted to be
658 incorporated into the multi-point SVG drawing object definitions (path,
659 polyline, polygon)
660
661 Input: attributes including:
662
663 -type = path type (path | polyline | polygon)
664 x = reference to array of x coordinates
665 y = reference to array of y coordinates
666
667 Output: a hash reference consisting of the following key-value pair:
668
669 points = the appropriate points-definition string
670 -type = path|polygon|polyline
671 -relative = 1 (define relative position rather than absolute position)
672 -closed = 1 (close the curve - path and polygon only)
673
674 #generate an open path definition for a path.
675 my ($points,$p);
676 $points = $svg->get_path(x=>\@x,y=>\@y,-relative=>1,-type=>'path');
677
678 #add the path to the SVG document
679 my $p = $svg->path(%$path, style=>\%style_definition);
680
681 #generate an closed path definition for a a polyline.
682 $points = $svg->get_path(
683 x=>\@x,
684 y=>\@y,
685 -relative=>1,
686 -type=>'polyline',
687 -closed=>1
688 ); # generate a closed path definition for a polyline
689
690 # add the polyline to the SVG document
691 $p = $svg->polyline(%$points, id=>'pline1');
692
693 Aliases: get_path set_path
694
695 animate
696 $tag = $svg->animate(%attributes)
697
698 Generate an SMIL animation tag. This is allowed within any nonempty
699 tag. Refer to the W3C for detailed information on the subtleties of the
700 animate SMIL commands.
701
702 Inputs: -method = Transform | Motion | Color
703
704 my $an_ellipse = $svg->ellipse(
705 cx => 30,
706 cy => 150,
707 rx => 10,
708 ry => 10,
709 id => 'an_ellipse',
710 stroke => 'rgb(130,220,70)',
711 fill =>'rgb(30,20,50)'
712 );
713
714 $an_ellipse-> animate(
715 attributeName => "cx",
716 values => "20; 200; 20",
717 dur => "10s",
718 repeatDur => 'indefinite'
719 );
720
721 $an_ellipse-> animate(
722 attributeName => "rx",
723 values => "10;30;20;100;50",
724 dur => "10s",
725 repeatDur => 'indefinite',
726 );
727
728 $an_ellipse-> animate(
729 attributeName => "ry",
730 values => "30;50;10;20;70;150",
731 dur => "15s",
732 repeatDur => 'indefinite',
733 );
734
735 $an_ellipse-> animate(
736 attributeName=>"rx",values=>"30;75;10;100;20;20;150",
737 dur=>"20s", repeatDur=>'indefinite');
738
739 $an_ellipse-> animate(
740 attributeName=>"fill",values=>"red;green;blue;cyan;yellow",
741 dur=>"5s", repeatDur=>'indefinite');
742
743 $an_ellipse-> animate(
744 attributeName=>"fill-opacity",values=>"0;1;0.5;0.75;1",
745 dur=>"20s",repeatDur=>'indefinite');
746
747 $an_ellipse-> animate(
748 attributeName=>"stroke-width",values=>"1;3;2;10;5",
749 dur=>"20s",repeatDur=>'indefinite');
750
751 group
752 $tag = $svg->group(%attributes)
753
754 Define a group of objects with common properties. Groups can have
755 style, animation, filters, transformations, and mouse actions assigned
756 to them.
757
758 $tag = $svg->group(
759 id => 'xvs000248',
760 style => {
761 'font' => [ qw( Arial Helvetica sans ) ],
762 'font-size' => 10,
763 'fill' => 'red',
764 },
765 transform => 'rotate(-45)'
766 );
767
768 defs
769 $tag = $svg->defs(%attributes)
770
771 define a definition segment. A Defs requires children when defined
772 using SVG.pm
773
774 $tag = $svg->defs(id => 'def_con_one',);
775
776 style
777 $svg->tag('style', %styledef);
778
779 Sets/adds style-definition for the following objects being created.
780
781 Style definitions apply to an object and all its children for all
782 properties for which the value of the property is not redefined by the
783 child.
784
785 $tag = $SVG->style(%attributes)
786
787 Generate a style container for inline or xlink:href based styling
788 instructions
789
790 my $tag = $SVG->style(type=>"text/css");
791
792 # Populate the style tag with cdata.
793 # Be careful to manage the line ends.
794 # Use qq{text}, where text is the script
795
796 $tag1->CDATA(qq{
797 rect fill:red;stroke:green;
798 circle fill:red;stroke:orange;
799 ellipse fill:none;stroke:yellow;
800 text fill:black;stroke:none;
801 });
802
803 # Create a external CSS stylesheet reference
804 my $tag2 = $SVG->style(type=>"text/css", -href="/resources/example.css");
805
806 mouseaction
807 $svg->mouseaction(%attributes)
808
809 Sets/Adds mouse action definitions for tag
810
811 attrib
812 $svg->attrib($name, $value)
813
814 Sets/adds attributes of an element.
815
816 Retrieve an attribute:
817
818 $svg->attrib($name);
819
820 Set a scalar attribute:
821
822 $SVG->attrib $name, $value
823
824 Set a list attribute:
825
826 $SVG->attrib $name, \@value
827
828 Set a hash attribute (i.e. style definitions):
829
830 $SVG->attrib $name, \%value
831
832 Remove an attribute:
833
834 $svg->attrib($name,undef);
835
836 Aliases: attr attribute
837
838 Sets/replaces attributes for a tag.
839
840 cdata
841 $svg->cdata($text)
842
843 Sets cdata to $text. SVG.pm allows you to set cdata for any tag. If the
844 tag is meant to be an empty tag, SVG.pm will not complain, but the
845 rendering agent will fail. In the SVG DTD, cdata is generally only
846 meant for adding text or script content.
847
848 $svg->text(
849 style => {
850 'font' => 'Arial',
851 'font-size' => 20
852 })->cdata('SVG.pm is a perl module on CPAN!');
853
854 my $text = $svg->text( style => { 'font' => 'Arial', 'font-size' => 20 } );
855 $text->cdata('SVG.pm is a perl module on CPAN!');
856
857 Result:
858
859 <text style="font: Arial; font-size: 20">SVG.pm is a perl module on CPAN!</text>
860
861 SEE ALSO:
862
863 "CDATA", "desc", "title", "text", "script".
864
865 cdata_noxmlesc
866 $script = $svg->script();
867 $script->cdata_noxmlesc($text);
868
869 Generates cdata content for text and similar tags which do not get xml-
870 escaped. In othe words, does not parse the content and inserts the
871 exact string into the cdata location.
872
873 CDATA
874 $script = $svg->script();
875 $script->CDATA($text);
876
877 Generates a <![CDATA[ ... ]]> tag with the contents of $text rendered
878 exactly as supplied. SVG.pm allows you to set cdata for any tag. If the
879 tag is meant to be an empty tag, SVG.pm will not complain, but the
880 rendering agent will fail. In the SVG DTD, cdata is generally only
881 meant for adding text or script content.
882
883 my $text = qq{
884 var SVGDoc;
885 var groups = new Array();
886 var last_group;
887
888 /*****
889 *
890 * init
891 *
892 * Find this SVG's document element
893 * Define members of each group by id
894 *
895 *****/
896 function init(e) {
897 SVGDoc = e.getTarget().getOwnerDocument();
898 append_group(1, 4, 6); // group 0
899 append_group(5, 4, 3); // group 1
900 append_group(2, 3); // group 2
901 }};
902 $svg->script()->CDATA($text);
903
904 Result:
905
906 E<lt>script E<gt>
907 <gt>![CDATA[
908 var SVGDoc;
909 var groups = new Array();
910 var last_group;
911
912 /*****
913 *
914 * init
915 *
916 * Find this SVG's document element
917 * Define members of each group by id
918 *
919 *****/
920 function init(e) {
921 SVGDoc = e.getTarget().getOwnerDocument();
922 append_group(1, 4, 6); // group 0
923 append_group(5, 4, 3); // group 1
924 append_group(2, 3); // group 2
925 }
926 ]]E<gt>
927
928 SEE ALSO: "cdata", "script".
929
930 xmlescp and xmlescape
931 $string = $svg->xmlescp($string)
932 $string = $svg->xmlesc($string)
933 $string = $svg->xmlescape($string)
934
935 SVG module does not xml-escape characters that are incompatible with
936 the XML specification. xmlescp and xmlescape provides this
937 functionality. It is a helper function which generates an XML-escaped
938 string for reserved characters such as ampersand, open and close
939 brackets, etcetera.
940
941 The behaviour of xmlesc is to apply the following transformation to the
942 input string $s:
943
944 $s=~s/&(?!#(x\w\w|\d+?);)/&/g;
945 $s=~s/>/>/g;
946 $s=~s/</</g;
947 $s=~s/\"/"/g;
948 $s=~s/\'/'/g;
949 $s=~s/([\x00-\x08\x0b\x1f])/''/eg;
950 $s=~s/([\200-\377])/'&#'.ord($1).';'/ge;
951
952 filter
953 $tag = $svg->filter(%attributes)
954
955 Generate a filter. Filter elements contain "fe" filter sub-elements.
956
957 my $filter = $svg->filter(
958 filterUnits=>"objectBoundingBox",
959 x=>"-10%",
960 y=>"-10%",
961 width=>"150%",
962 height=>"150%",
963 filterUnits=>'objectBoundingBox'
964 );
965
966 $filter->fe();
967
968 SEE ALSO: "fe".
969
970 fe
971 $tag = $svg->fe(-type=>'type', %attributes)
972
973 Generate a filter sub-element. Must be a child of a "filter" element.
974
975 my $fe = $svg->fe(
976 -type => 'DiffuseLighting' # required - element name omitting 'fe'
977 id => 'filter_1',
978 style => {
979 'font' => [ qw(Arial Helvetica sans) ],
980 'font-size' => 10,
981 'fill' => 'red',
982 },
983 transform => 'rotate(-45)'
984 );
985
986 Note that the following filter elements are currently supported: Also
987 note that the elelemts are defined in lower case in the module, but as
988 of version 2.441, any case combination is allowed.
989
990 * feBlend
991 * feColorMatrix
992 * feComponentTransfer
993 * feComposite
994 * feConvolveMatrix
995 * feDiffuseLighting
996 * feDisplacementMap
997 * feDistantLight
998 * feFlood
999 * feFuncA
1000 * feFuncB
1001 * feFuncG
1002 * feFuncR
1003 * feGaussianBlur
1004 * feImage
1005 * feMerge
1006 * feMergeNode
1007 * feMorphology
1008 * feOffset
1009 * fePointLight
1010 * feSpecularLighting
1011 * feSpotLight
1012 * feTile
1013 * feTurbulence
1014 SEE ALSO: "filter".
1015
1016 pattern
1017 $tag = $svg->pattern(%attributes)
1018
1019 Define a pattern for later reference by url.
1020
1021 my $pattern = $svg->pattern(
1022 id => "Argyle_1",
1023 width => "50",
1024 height => "50",
1025 patternUnits => "userSpaceOnUse",
1026 patternContentUnits => "userSpaceOnUse"
1027 );
1028
1029 set
1030 $tag = $svg->set(%attributes)
1031
1032 Set a definition for an SVG object in one section, to be referenced in
1033 other sections as needed.
1034
1035 my $set = $svg->set(
1036 id => "Argyle_1",
1037 width => "50",
1038 height => "50",
1039 patternUnits => "userSpaceOnUse",
1040 patternContentUnits => "userSpaceOnUse"
1041 );
1042
1043 stop
1044 $tag = $svg->stop(%attributes)
1045
1046 Define a stop boundary for "gradient"
1047
1048 my $pattern = $svg->stop(
1049 id => "Argyle_1",
1050 width => "50",
1051 height => "50",
1052 patternUnits => "userSpaceOnUse",
1053 patternContentUnits => "userSpaceOnUse"
1054 );
1055
1056 gradient
1057 $tag = $svg->gradient(%attributes)
1058
1059 Define a color gradient. Can be of type linear or radial
1060
1061 my $gradient = $svg->gradient(
1062 -type => "linear",
1063 id => "gradient_1"
1064 );
1065
1067 The following elements are generically supported by SVG:
1068
1069 * altGlyph
1070 * altGlyphDef
1071 * altGlyphItem
1072 * clipPath
1073 * color-profile
1074 * cursor
1075 * definition-src
1076 * font-face-format
1077 * font-face-name
1078 * font-face-src
1079 * font-face-url
1080 * foreignObject
1081 * glyph
1082 * glyphRef
1083 * hkern
1084 * marker
1085 * mask
1086 * metadata
1087 * missing-glyph
1088 * mpath
1089 * switch
1090 * symbol
1091 * tref
1092 * view
1093 * vkern
1094 See e.g. "pattern" for an example of the use of these methods.
1095
1097 The following SVG::DOM elements are accessible through SVG:
1098
1099 * getChildren
1100 * getFirstChild
1101 * getNextChild
1102 * getLastChild
1103 * getParent
1104 * getParentElement
1105 * getSiblings
1106 * getElementByID
1107 * getElementID
1108 * getElements
1109 * getElementName
1110 * getType
1111 * getAttributes
1112 * getAttribute
1113 * setAttributes
1114 * setAttribute
1115 * insertBefore
1116 * insertAfter
1117 * insertSiblingBefore
1118 * insertSiblingAfter
1119 * replaceChild
1120 * removeChild
1121 * cloneNode
1123 SVG provides both explicit and generic element constructor methods.
1124 Explicit generators are generally (with a few exceptions) named for the
1125 element they generate. If a tag method is required for a tag containing
1126 hyphens, the method name replaces the hyphen with an underscore. ie: to
1127 generate tag <column-heading id="new"> you would use method
1128 $svg->column_heading(id=>'new').
1129
1130 All element constructors take a hash of element attributes and options;
1131 element attributes such as 'id' or 'border' are passed by name, while
1132 options for the method (such as the type of an element that supports
1133 multiple alternate forms) are passed preceded by a hyphen, e.g '-type'.
1134 Both types may be freely intermixed; see the "fe" method and code
1135 examples throughout the documentation for more examples.
1136
1137 new (constructor)
1138 $svg = SVG->new(%attributes)
1139
1140 Creates a new SVG object. Attributes of the document SVG element be
1141 passed as an optional list of key value pairs. Additionally, SVG
1142 options (prefixed with a hyphen) may be set on a per object basis:
1143
1144 my $svg1 = SVG->new;
1145
1146 my $svg2 = SVG->new(id => 'document_element');
1147
1148 my $svg3 = SVG->new(
1149 -printerror => 1,
1150 -raiseerror => 0,
1151 -indent => ' ',
1152 -elsep => "\n", # element line (vertical) separator
1153 -docroot => 'svg', # default document root element (SVG specification assumes svg). Defaults to 'svg' if undefined
1154 -xml_xlink => 'http://www.w3.org/1999/xlink', # required by Mozilla's embedded SVG engine
1155 -sysid => 'abc', # optional system identifier
1156 -pubid => "-//W3C//DTD SVG 1.0//EN", # public identifier default value is "-//W3C//DTD SVG 1.0//EN" if undefined
1157 -namespace => 'mysvg',
1158 -inline => 1
1159 id => 'document_element',
1160 width => 300,
1161 height => 200,
1162 );
1163
1164 Default SVG options may also be set in the import list. See "EXPORTS"
1165 above for more on the available options.
1166
1167 Furthermore, the following options:
1168
1169 -version
1170 -encoding
1171 -standalone
1172 -namespace
1173 -inline
1174 -pubid (formerly -identifier)
1175 -sysid (standalone)
1176
1177 may also be set in xmlify, overriding any corresponding values set in
1178 the SVG->new declaration
1179
1180 xmlify (alias: to_xml render serialize serialise )
1181 $string = $svg->xmlify(%attributes);
1182
1183 Returns xml representation of svg document.
1184
1185 XML Declaration
1186
1187 Name Default Value
1188 -version '1.0'
1189 -encoding 'UTF-8'
1190 -standalone 'yes'
1191 -namespace 'svg' - namespace prefix for elements.
1192 Can also be used in any element method to over-ride
1193 the current namespace prefix. Make sure to have
1194 declared the prefix before using it.
1195 -inline '0' - If '1', then this is an inline document.
1196 -pubid '-//W3C//DTD SVG 1.0//EN';
1197 -sysid 'http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd'
1198
1199 perlify ()
1200 return the perl code which generates the SVG document as it currently
1201 exists.
1202
1203 toperl ()
1204 Alias for method perlify()
1205
1207 Ronan Oger, RO IT Systemms GmbH, cpan@roitsystems.com
1208
1210 Gabor Szabo <http://szabgab.com/>
1211
1213 I would like to thank the following people for contributing to this
1214 module with patches, testing, suggestions, and other nice tidbits:
1215
1216 Peter Wainwright, Excellent ideas, beta-testing, writing SVG::Parser
1217 and much of SVG::DOM. Fredo, http://www.penguin.at0.net/~fredo/ -
1218 provided example code and initial feedback for early SVG.pm versions
1219 and the idea of a simplified svg generator. Adam Schneider Brial
1220 Pilpré Ian Hickson Steve Lihn Allen Day Martin Owens - SVG::DOM
1221 improvements in version 3.34
1222
1224 Copyright 2001- Ronan Oger
1225
1226 The modules in the SVG distribution are distributed under the same
1227 license as Perl itself. It is provided free of warranty and may be re-
1228 used freely.
1229
1231 SVG using Perl <http://szabgab.com/svg-using-perl.html>
1232
1233 SVG - Scalable Vector Graphics with Perl
1234 <http://perlmaven.com/scalable-vector-graphics-with-perl>
1235
1236 Combining SVG and PSGI <http://perlmaven.com/combining-svg-and-psgi>
1237
1239 SVG::DOM, SVG::XML, SVG::Element, SVG::Parser, SVG::Extension
1240
1241 For Commercial Perl/SVG development, refer to the following sites: SVG
1242 at the W3C <http://www.w3c.org/Graphics/SVG/>.
1243
1244
1245
1246perl v5.36.0 2022-07-22 SVG(3)