1 <?xml version=
"1.0" encoding=
"UTF-8"?>
2 <!-- =====================================================================-->
4 <!-- text-text-05-t.svg -->
6 <!-- Tests that the viewer can handle the rotate attribute on the text -->
9 <!-- Author : Vincent Hardy, 06-Jan-2004 --><!DOCTYPE svg PUBLIC
"-//W3C//DTD SVG 1.1 Tiny//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11-tiny.dtd">
11 <svg onload=
"runRepaintAndPixelTest()" xmlns=
"http://www.w3.org/2000/svg" xmlns:
xlink=
"http://www.w3.org/1999/xlink" version=
"1.1" baseProfile=
"tiny" id=
"svg-root" width=
"100%" height=
"100%" viewBox=
"0 0 480 360">
12 <SVGTestCase xmlns:
testcase=
"http://www.w3.org/2000/02/svg/testsuite/description/" xmlns=
"http://www.w3.org/2000/02/svg/testsuite/description/" owner=
"VH" desc=
"Tests that the viewer can handle the rotate attribute on the text element" status=
"accepted" version=
"$Revision: 1.8 $" testname=
"$RCSfile: text-text-05-t.svg,v $">
15 The purpose of this test is to validate the interaction of text-anchor
16 and x/y glyph positioning.
19 Each row shows a different combination of x/y values:
1, more than characters,
20 fewer than characters. Each column shows different anchor values: start, middle
24 The blue markers show the various x/y absolute positions around which text
25 chunks should be anchored. The glyphs are black squares of increasing sizes.
29 <title id=
"test-title">text-fontSize-
01-t.svg
</title>
30 <desc id=
"test-desc"/>
32 <script xlink:
href=
"../../fast/repaint/resources/text-based-repaint.js"></script>
33 <!--======================================================================-->
34 <!--Content of Test Case follows... =====================-->
35 <!--======================================================================-->
36 <g id=
"test-body-content" font-size=
"16">
38 <font id=
"embeded" horiz-adv-x=
"224">
39 <font-face font-family=
"embeded" units-per-em=
"1000" panose-1=
"0 0 0 0 0 0 0 0 0 0" ascent=
"917" descent=
"-250" alphabetic=
"0"/>
40 <missing-glyph horiz-adv-x=
"800" d=
"M50 0V800H750V0H50ZM700 50V750H100V50H700Z"/>
41 <glyph unicode=
"1" glyph-name=
"gl_1" horiz-adv-x=
"1500" d=
"M 0 0 L 250 0 L 250 250 L 0 250 Z"/>
42 <glyph unicode=
"2" glyph-name=
"gl_2" horiz-adv-x=
"1500" d=
"M 0 0 L 500 0 L 500 500 L 0 500 Z"/>
43 <glyph unicode=
"3" glyph-name=
"gl_3" horiz-adv-x=
"1500" d=
"M 0 0 L 750 0 L 750 750 L 0 750 Z"/>
44 <glyph unicode=
"4" glyph-name=
"gl_4" horiz-adv-x=
"1500" d=
"M 0 0 L 1000 0 L 1000 1000 L 0 1000 Z"/>
51 <line y2=
"-15" stroke=
"red"/>
52 <rect x=
"-4" y=
"-4" width=
"8" height=
"8"/>
56 <g id=
"legend" transform=
"translate(10, 40)">
57 <text y=
"30">1.x
1.y
</text>
58 <text y=
"60">4.x
1.y
</text>
59 <text y=
"90">2.x
1.y
</text>
60 <text y=
"120">1.x
4.y
</text>
61 <text y=
"150">4.x
4.y
</text>
62 <text y=
"180">2.x
4.y
</text>
63 <text y=
"210">1.x
2.y
</text>
64 <text y=
"240">4.x
2.y
</text>
65 <text y=
"270">2.x
2.y
</text>
68 <g id=
"anchorStart" text-anchor=
"start" transform=
"translate(150, 40)">
69 <text y=
"-17" text-anchor=
"middle">text-anchor
</text>
70 <text y=
"-3" text-anchor=
"middle">start
</text>
71 <line x1=
"0" y1=
"10" x2=
"0" y2=
"290" stroke=
"red"/>
75 <use y=
"30" xlink:
href=
"#marker" fill=
"#8888ff"/>
76 <text x=
"0" y=
"30" font-family=
"embeded" font-size=
"10">1234</text>
78 <!-- 4.x 1.y : four text chunks -->
79 <use x=
"10" y=
"60" xlink:
href=
"#marker" fill=
"#8888ff"/>
80 <use x=
"20" y=
"60" xlink:
href=
"#marker" fill=
"#8888ff"/>
81 <use x=
"30" y=
"60" xlink:
href=
"#marker" fill=
"#8888ff"/>
82 <use x=
"40" y=
"60" xlink:
href=
"#marker" fill=
"#8888ff"/>
83 <text x=
"10 20 30 40" y=
"60" font-family=
"embeded" font-size=
"10">1234</text>
85 <!-- 2.x 1.y : two text chunks -->
86 <use x=
"10" y=
"90" xlink:
href=
"#marker" fill=
"#8888ff"/>
87 <use x=
"60" y=
"90" xlink:
href=
"#marker" fill=
"#8888ff"/>
88 <text x=
"10 60" y=
"90" font-family=
"embeded" font-size=
"10">1234</text>
90 <!-- 1.x 4.y : four text chunks -->
91 <g transform=
"translate(0, 120)">
92 <use x=
"0" y=
"-10" xlink:
href=
"#marker" fill=
"#8888ff"/>
93 <use x=
"15" y=
"-5" xlink:
href=
"#marker" fill=
"#8888ff"/>
94 <use x=
"30" y=
"5" xlink:
href=
"#marker" fill=
"#8888ff"/>
95 <use x=
"45" y=
"10" xlink:
href=
"#marker" fill=
"#8888ff"/>
96 <text x=
"0" y=
"-10 -5 5 10" font-family=
"embeded" font-size=
"10">1234</text>
99 <!-- 4.x 4.y : four text chunks -->
100 <g transform=
"translate(0, 150)">
101 <use x=
"10" y=
"-10" xlink:
href=
"#marker" fill=
"#8888ff"/>
102 <use x=
"20" y=
"-5" xlink:
href=
"#marker" fill=
"#8888ff"/>
103 <use x=
"30" y=
"5" xlink:
href=
"#marker" fill=
"#8888ff"/>
104 <use x=
"40" y=
"10" xlink:
href=
"#marker" fill=
"#8888ff"/>
105 <text x=
"10 20 30 40" y=
"-10 -5 5 10" font-family=
"embeded" font-size=
"10">1234</text>
108 <!-- 2.x 4.y : four text chunks -->
109 <g transform=
"translate(0, 180)">
110 <use x=
"10" y=
"-10" xlink:
href=
"#marker" fill=
"#8888ff"/>
111 <use x=
"20" y=
"-5" xlink:
href=
"#marker" fill=
"#8888ff"/>
112 <use x=
"35" y=
"5" xlink:
href=
"#marker" fill=
"#8888ff"/>
113 <use x=
"50" y=
"10" xlink:
href=
"#marker" fill=
"#8888ff"/>
114 <text x=
"10 20" y=
"-10 -5 5 10" font-family=
"embeded" font-size=
"10">1234</text>
117 <!-- 1.x 2.y : two text chunks -->
118 <g transform=
"translate(0, 210)">
119 <use x=
"0" y=
"-10" xlink:
href=
"#marker" fill=
"#8888ff"/>
120 <use x=
"15" y=
"5" xlink:
href=
"#marker" fill=
"#8888ff"/>
121 <text x=
"0" y=
"-10 5" font-family=
"embeded" font-size=
"10">1234</text>
124 <!-- 4.x 2.y : four text chunks -->
125 <g transform=
"translate(0, 240)">
126 <use x=
"10" y=
"-10" xlink:
href=
"#marker" fill=
"#8888ff"/>
127 <use x=
"20" y=
"-5" xlink:
href=
"#marker" fill=
"#8888ff"/>
128 <use x=
"30" y=
"-5" xlink:
href=
"#marker" fill=
"#8888ff"/>
129 <use x=
"40" y=
"-5" xlink:
href=
"#marker" fill=
"#8888ff"/>
130 <text x=
"10 20 30 40" y=
"-10 -5" font-family=
"embeded" font-size=
"10">1234</text>
133 <!-- 2.x 2.y : two text chunks -->
134 <g transform=
"translate(0, 270)">
135 <use x=
"10" y=
"-10" xlink:
href=
"#marker" fill=
"#8888ff"/>
136 <use x=
"60" y=
"-5" xlink:
href=
"#marker" fill=
"#8888ff"/>
137 <text x=
"10 60" y=
"-10 -5" font-family=
"embeded" font-size=
"10">1234</text>
143 <g id=
"anchorMiddle" text-anchor=
"middle" transform=
"translate(250, 40)">
144 <text y=
"-17" text-anchor=
"middle">text-anchor
</text>
145 <text y=
"-3" text-anchor=
"middle">middle
</text>
146 <line x1=
"0" y1=
"10" x2=
"0" y2=
"290" stroke=
"red"/>
147 <use xlink:
href=
"#textContent"/>
150 <g id=
"anchorEnd" text-anchor=
"end" transform=
"translate(350, 40)">
151 <text y=
"-17" text-anchor=
"middle">text-anchor
</text>
152 <text y=
"-3" text-anchor=
"middle">end
</text>
153 <line x1=
"0" y1=
"10" x2=
"0" y2=
"290" stroke=
"red"/>
154 <use xlink:
href=
"#textContent"/>
159 <text id=
"revision" x=
"10" y=
"350" font-size=
"40" stroke=
"none" fill=
"black">$Revision:
1.8 $
</text>
160 <rect id=
"test-frame" x=
"1" y=
"1" width=
"478" height=
"358" fill=
"none" stroke=
"#000000"/>
163 if (window.testRunner)
164 testRunner.dumpSelectionRect();
166 function repaintTest() {
167 var range = document.createRange();
168 range.selectNode(window.document.documentElement);
169 var selection = window.getSelection();
170 selection.removeAllRanges();
171 selection.addRange(range);