Files
openlayers/master/examples/test_SurfaceGroupSilverlight.html
Éric Lemoine 5d14b9e2d4 Updated
2013-02-20 10:38:25 +01:00

180 lines
6.3 KiB
HTML

<html dir="rtl">
<head>
<title>Testing textpath</title>
<style type="text/css">
@import "../../../../../dojo/resources/dojo.css";
@import "../../../../../dijit/tests/css/dijitTests.css";
</style>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script type="text/javascript" src="../../../../../dojo/dojo.js" djConfig="isDebug: true, gfxRenderer:'silverlight'"></script>
<script type="text/javascript">
dojo.require("dojox.gfx");
dojo.require("dojox.gfx._gfxBidiSupport");
dojo.require("doh.runner");
var CPD = 30, tp3, t1, t2, t3, t4, t5, t6;
var g1 = null, g2 = null, g3, g4;
var surfaceLTR = null, surfaceRTL = null, surfaceAUTO = null;
var placeAnchor = function(surface, x, y){
surface.createLine({x1: x - 2, y1: y, x2: x + 2, y2: y});
surface.createLine({x1: x, y1: y - 2, x2: x, y2: y + 2});
};
var makeText = function(surface, text, font, fill, stroke){
var t = surface.createText(text);
if(font) t.setFont(font);
if(fill) t.setFill(fill);
if(stroke) t.setStroke(stroke);
placeAnchor(surface, text.x, text.y);
return t;
};
makeShapes = function(){
var m = dojox.gfx.matrix;
surfaceLTR = dojox.gfx.createSurface("testLTR", 500, 170, "ltr");
console.debug("surfaceLTR created");
var p = surfaceLTR.createPath({})
.moveTo(0, 15)
.setAbsoluteMode(false)
.curveTo(CPD, 0, 0, 0, 50, 0)
;
console.debug("p created");
g1 = surfaceLTR.createGroup();
g1.setTextDir("rtl");
// surfaceLTR.setTextDir("ltr");
t1 = makeText(g1, {id: "t1",x: 0, y: 100, text: "1.) \u05e9\u05dc\u05d5\u05dd world!"},
{family: "Times", size: "18pt"}, "black", "blue")
.setTransform(m.rotategAt(0, 250, 150));
t2 = makeText(surfaceLTR, {x: 0, y: 140, text: "1.) Hello \u05e2\u05d5\u05dc\u05dd!"},
{family: "Times", size: "18pt"}, "black", "blue")
.setTransform(m.rotategAt(0, 250, 100));
surfaceRTL = dojox.gfx.createSurface("testRTL", 500, 170);
console.debug("surfaceRTL created");
var p2 = surfaceRTL.createPath({})
.moveTo(0, 15)
.setAbsoluteMode(false)
.curveTo(CPD, 0, 0, 0, 100, 0)
;
console.debug("p2 created");
tp3 = makeText(surfaceRTL, {x: 0, y: 160, text: "\u05d4\u05ea\u05d7\u05dc\u05d4 end. "},
{family: "Times", size: "18pt"}, "black", "blue")
.setTransform(m.rotategAt(0, 250, 100));
g2 = surfaceRTL.createGroup();
g2.add(tp3);
g2.setTextDir("ltr");
g3 = g2.createGroup("rtl");
g4 = surfaceRTL.createGroup("auto");
console.debug("tp3 created");
t3 = makeText(g3, {id: "t1",x: 0, y: 100, text: "1.) \u05e9\u05dc\u05d5\u05dd world!"},
{family: "Times", size: "18pt"}, "black", "red")
.setTransform(m.rotategAt(0, 250, 150));
t4 = makeText(surfaceRTL, {x: 0, y: 140, text: "1.) Hello \u05e2\u05d5\u05dc\u05dd!"},
{family: "Times", size: "18pt"}, "black", "red")
.setTransform(m.rotategAt(0, 250, 100));
surfaceAUTO = dojox.gfx.createSurface("testAUTO", 500, 170,"auto");
console.debug("surfaceAUTO created");
var p3 = surfaceAUTO.createPath({})
.moveTo(0, 15)
.setAbsoluteMode(false)
.curveTo(CPD, 0, 0, 0, 100, 0)
;
console.debug("p3 created");
t5 = makeText(surfaceAUTO, {id: "t1",x: 0, y: 100, text: "1.) \u05e9\u05dc\u05d5\u05dd world!"},
{family: "Times", size: "18pt"}, "black", "red")
.setTransform(m.rotategAt(0, 250, 150));
t6 = makeText(surfaceAUTO, {x: 0, y: 140, text: "1.) Hello \u05e2\u05d5\u05dc\u05dd!"},
{family: "Times", size: "18pt"}, "black", "blue")
.setTransform(m.rotategAt(0, 250, 100));
};
dojo.addOnLoad(function(){
makeShapes();
doh.register("Test inheritance", [
function surfaces_TextDir(){
doh.is("ltr", surfaceLTR.getTextDir(), "surfaceLTR.getTextDir");
doh.is("rtl", surfaceRTL.getTextDir(), "surfaceRTL.getTextDir");
doh.is("auto", surfaceAUTO.getTextDir(), "surfaceAUTO.getTextDir");
},
function groups_TextDir(){
doh.is("rtl", g1.getTextDir(), "g1.getTextDir");
doh.is("ltr", g2.getTextDir(), "g2.getTextDir");
doh.is("rtl", g3.getTextDir(), "g3.getTextDir");
doh.is("auto", g4.getTextDir(), "g4.getTextDir");
},
function gfxText_TextDir(){
doh.is("rtl", t1.textDir, "t1.getTextDir");
doh.is("ltr", t2.textDir, "t2.getTextDir");
doh.is("rtl", t3.textDir, "t3.getTextDir");
doh.is("rtl", t4.textDir, "t4.getTextDir");
doh.is("auto", t5.textDir, "t5.getTextDir");
doh.is("auto", t6.textDir, "t6.getTextDir");
doh.is("ltr", tp3.textDir, "tp3.getTextDir");
},
function changeSurfaceRTLextDir(){
surfaceRTL.setTextDir("ltr");
doh.is("ltr", surfaceRTL.getTextDir(), "surfaceRTL.getTextDir");
doh.is("ltr", g2.getTextDir(), "g2.getTextDir");
doh.is("ltr", g3.getTextDir(), "g3.getTextDir");
doh.is("ltr", g4.getTextDir(), "g4.getTextDir");
doh.is("ltr", t3.textDir, "t3.getTextDir");
doh.is("ltr", t4.textDir, "t4.getTextDir");
doh.is("ltr", tp3.textDir, "tp3.getTextDir");
},
function changeGroupTextDir(){
// add doesn't work for silverlight because of the rawNode call.
// g3.add(t5);
// g3.add(t2);
g2.setTextDir("rtl");
doh.is("rtl", g2.getTextDir(), "g2.getTextDir");
// son of g2
doh.is("rtl", g3.getTextDir(), "g3.getTextDir");
// doh.is("rtl", t2.textDir, "t2.getTextDir");
doh.is("rtl", t3.textDir, "t3.getTextDir");
// doh.is("rtl", t5.textDir, "t5.getTextDir");
}
]);
doh.run();
});
</script>
</head>
<body>
<h1>dojox.gfx Text on a Path test</h1>
<h2>LTR TextPath and Text first two are TextPath and two others are Text</h2>
<div id="testLTR" style="width: 500px;"></div>
<h2>RTL Text Path and Text first two are TextPath and two others are Text</h2>
<div id="testRTL" style="width: 500px;"></div>
<h2>AUTO Text Path and Text first two are TextPath and two others are Text</h2>
<div id="testAUTO" style="width: 500px;"></div>
<p>That's all Folks!</p>
</body>
</html>