1 <?xml version=
"1.0" encoding=
"UTF-8"?>
2 <!DOCTYPE svg PUBLIC
"-//W3C//DTD SVG 1.1 Full//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11-flat.dtd">
3 <svg version=
"1.1" baseProfile=
"full" id=
"svg-root" width=
"100%" height=
"100%" viewBox=
"0 0 480 360" xmlns=
"http://www.w3.org/2000/svg"
4 xmlns:
xlink=
"http://www.w3.org/1999/xlink" onload=
"doSelection(0,0);">
5 <!--========================================================================-->
6 <!--= Copyright 2006 World Wide Web Consortium, (Massachusetts =-->
7 <!--= Institute of Technology, European Research Consortium for =-->
8 <!--= Informatics and Mathematics (ERCIM), Keio University). =-->
9 <!--= All Rights Reserved. =-->
10 <!--= See http://www.w3.org/Consortium/Legal/. =-->
11 <!--========================================================================-->
12 <!-- NOTE: CVS will automatically update the -->
13 <!-- "$RCSfile: text-tselect-02-f.svg,v $" and "$Revision: 1.2 $" -->
14 <!-- fields in the file. -->
15 <!-- There is no need to update this information. -->
16 <!-- =====================================================================-->
17 <SVGTestCase xmlns=
"http://www.w3.org/2000/02/svg/testsuite/description/" reviewer=
"CL" owner=
"ED" desc=
"Tests bidirectional text selection" status=
"created" version=
"$Revision: 1.2 $" testname=
"$RCSfile: text-tselect-02-f.svg,v $">
20 This test demonstrates text selection of bidirectional text.
21 The initial result should be that the first
9 characters in logical order
22 starting from logical position
0 are selected. Visually the selection is
23 discontigous and these substrings must be selected (listed in visual order):
29 the space between
"c" and
"ו"
35 the space between
"3" and
"ג"
38 "אבג"
41 If only the substrings listed above were selected then the test has passed.
44 A user agent that allows selecting text in logical order would have generated the same selection
45 as in this testcase if the user started the selection on the character
"a" and ended it on the
48 A user agent that allows selecting text in visual order would not have a discontigous selection
49 if the user started the selection on the character
"a" and ended it on the character
"1". The copied
50 text would be discontigous instead in this case.
52 Note that the SVG DOM method requires logical order text selection, so for both types of user agents
53 this testcase must look the same.
56 The testcase also shows what happens when the selection is modified via DOM (click the buttons below
57 the bidi-text). Compliant viewers must throw an exception when the first parameter handed
58 to SVGTextContentElement.selectSubString is out-of-range.
59 That means the variable 'startIndex' must always be in the range
0 <= startIndex
<=
18.
60 It can be noted that the parameter 'numChars' is not restricted in this way.
63 Note that the color of the text selection is UA dependent and not defined in the SVG specification.
67 <title id=
"test-title">$RCSfile: text-tselect-
02-f.svg,v $
</title>
68 <!--======================================================================-->
69 <!--Content of Test Case follows... =====================-->
70 <!--======================================================================-->
71 <g id=
"test-body-content">
77 function doSelection(indexDelta, numCharsDelta)
81 document.getElementById('text').selectSubString(startIndex+indexDelta, numChars+numCharsDelta);
85 if(e.code == DOMException.INDEX_SIZE_ERR)
87 // If there was an error, re-select the last range
88 document.getElementById('text').selectSubString(startIndex, numChars);
93 startIndex += indexDelta;
94 numChars += numCharsDelta;
96 document.getElementById('info').firstChild.data =
"StartIndex: " + startIndex +
". NumChars: " + numChars;
101 <g transform=
"translate(0,60)">
102 <text id=
"info" font-size=
"16" x=
"10" y=
"70">StartIndex:
0 NumChars:
0</text>
104 <text id=
"text" font-size=
"48" y=
"128" x=
"10">
105 abc
אבג 123 דהו def
109 <rect x=
"10" y=
"160" width=
"100" height=
"20" fill=
"blue" onclick=
"doSelection(1,0);"/>
110 <text x=
"60" y=
"175" text-anchor=
"middle" font-size=
"16" fill=
"white" pointer-events=
"none">startIndex++
</text>
112 <rect x=
"120" y=
"160" width=
"100" height=
"20" fill=
"blue" onclick=
"doSelection(-1,0);"/>
113 <text x=
"170" y=
"175" text-anchor=
"middle" font-size=
"16" fill=
"white" pointer-events=
"none">startIndex--
</text>
115 <rect x=
"230" y=
"160" width=
"100" height=
"20" fill=
"blue" onclick=
"doSelection(0,1);"/>
116 <text x=
"280" y=
"175" text-anchor=
"middle" font-size=
"16" fill=
"white" pointer-events=
"none">numChars++
</text>
118 <rect x=
"340" y=
"160" width=
"100" height=
"20" fill=
"blue" onclick=
"doSelection(0,-1);"/>
119 <text x=
"390" y=
"175" text-anchor=
"middle" font-size=
"16" fill=
"white" pointer-events=
"none">numChars--
</text>
123 <text id=
"revision" x=
"10" y=
"340" font-size=
"40" stroke=
"none" fill=
"black">$Revision:
1.2 $
</text>
124 <rect id=
"test-frame" x=
"1" y=
"1" width=
"478" height=
"358" fill=
"none" stroke=
"#000"/>
126 if (window.testRunner)
127 window.testRunner.dumpSelectionRect();
128 var range = document.createRange();
129 range.selectNode(window.document.documentElement);
130 var selection = window.getSelection();
131 selection.removeAllRanges();
132 selection.addRange(range);