1 | <?xml version="1.0" encoding="UTF-8"?>
|
---|
2 | <schema targetNamespace="https://josm.openstreetmap.de/gpx-drawing-extensions-1.0"
|
---|
3 | elementFormDefault="qualified"
|
---|
4 | xmlns="http://www.w3.org/2001/XMLSchema"
|
---|
5 | xmlns:xsd="http://www.w3.org/2001/XMLSchema"
|
---|
6 | xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
---|
7 | xmlns:gpxd="https://josm.openstreetmap.de/gpx-drawing-extensions-1.0"
|
---|
8 | xsi:schemaLocation="https://josm.openstreetmap.de/gpx-drawing-extensions-1.0 https://josm.openstreetmap.de/gpx-drawing-extensions-1.0.xsd">
|
---|
9 |
|
---|
10 | <xsd:annotation>
|
---|
11 | <xsd:documentation>
|
---|
12 | This schema defines drawing extensions for the GPX 1.1 schema (http://www.topografix.com/GPX/1/1/gpx.xsd).
|
---|
13 | Elements in this schema should be used as child elements of the "extensions" element defined by the GPX schema.
|
---|
14 | </xsd:documentation>
|
---|
15 | </xsd:annotation>
|
---|
16 |
|
---|
17 | <!-- Elements -->
|
---|
18 |
|
---|
19 | <xsd:element name="color" type="gpxd:hexColor_type">
|
---|
20 | <xsd:annotation>
|
---|
21 | <xsd:documentation>
|
---|
22 | The color of the element, i.e. #RRGGBB or #RRGGBBAA.
|
---|
23 | Note that applications should apply possible alpha values to the lines and opacity to the whole track. This means that overlapping parts of the
|
---|
24 | track with alpha values will look more intense than individual lines, whereas the opacity affects the whole track including overlapping parts.
|
---|
25 | </xsd:documentation>
|
---|
26 | </xsd:annotation>
|
---|
27 | </xsd:element>
|
---|
28 |
|
---|
29 | <xsd:element name="opacity" type="gpxd:opacity_type">
|
---|
30 | <xsd:annotation>
|
---|
31 | <xsd:documentation>
|
---|
32 | The opacity of the element between 0.00 and 1.00.
|
---|
33 | </xsd:documentation>
|
---|
34 | </xsd:annotation>
|
---|
35 | </xsd:element>
|
---|
36 |
|
---|
37 | <xsd:element name="width" type="xsd:positiveInteger">
|
---|
38 | <xsd:annotation>
|
---|
39 | <xsd:documentation>
|
---|
40 | The width of the line in pixels, applications may use a width relative to this value if required.
|
---|
41 | </xsd:documentation>
|
---|
42 | </xsd:annotation>
|
---|
43 | </xsd:element>
|
---|
44 |
|
---|
45 | <xsd:element name="dashPattern" type="gpxd:dashPattern_type">
|
---|
46 | <xsd:annotation>
|
---|
47 | <xsd:documentation>
|
---|
48 | The dash pattern of the line, see gpxd:dashPattern_type. Should always be relative to the width.
|
---|
49 | </xsd:documentation>
|
---|
50 | </xsd:annotation>
|
---|
51 | </xsd:element>
|
---|
52 |
|
---|
53 | <!-- Types -->
|
---|
54 |
|
---|
55 | <xsd:simpleType name="hexColor_type">
|
---|
56 | <xsd:annotation>
|
---|
57 | <xsd:documentation>
|
---|
58 | The hexColor_type must be a # followed by a 6 or 8-digit hex representation of the color (with or without the alpha value).
|
---|
59 | </xsd:documentation>
|
---|
60 | </xsd:annotation>
|
---|
61 | <xsd:restriction base="xsd:string">
|
---|
62 | <xsd:pattern value="\#([a-fA-F0-9]{6}|[a-fA-F0-9]{8})" />
|
---|
63 | <xsd:whiteSpace value="collapse" />
|
---|
64 | </xsd:restriction>
|
---|
65 | </xsd:simpleType>
|
---|
66 |
|
---|
67 | <xsd:simpleType name="opacity_type">
|
---|
68 | <xsd:annotation>
|
---|
69 | <xsd:documentation>
|
---|
70 | The opacity_type must be a decimal value between 0 and 1.
|
---|
71 | </xsd:documentation>
|
---|
72 | </xsd:annotation>
|
---|
73 | <xsd:restriction base="xsd:decimal">
|
---|
74 | <xsd:minInclusive value="0" />
|
---|
75 | <xsd:maxInclusive value="1" />
|
---|
76 | </xsd:restriction>
|
---|
77 | </xsd:simpleType>
|
---|
78 |
|
---|
79 | <xsd:simpleType name="dashPattern_type">
|
---|
80 | <xsd:annotation>
|
---|
81 | <xsd:documentation>
|
---|
82 | The dashPattern_type can be
|
---|
83 | - a representation of the pattern as y-n-y-n-... with y being the relative length of the line that is
|
---|
84 | visible and n being the relative length of the line that is hidden to create a dashed / dotted line.
|
---|
85 | Has to have an even number of segments (at least two) and can contain multi-digit numbers.
|
---|
86 | - one of the following predefined values:
|
---|
87 | none, dash-long, dash-medium, dash-short, dot-sparse, dot-normal, dot-dense, dash-dot, dash-dot-dot
|
---|
88 | </xsd:documentation>
|
---|
89 | </xsd:annotation>
|
---|
90 | <xsd:restriction base="xsd:string"> <!-- use string based pattern instead of enum because both pattern and enums are allowed -->
|
---|
91 | <xsd:pattern value="\d+\-\d+(\-\d+\-\d+)*" /> <!-- pattern, see documentation above -->
|
---|
92 | <xsd:pattern value="none" /> <!-- 1-0, default value/line -->
|
---|
93 | <xsd:pattern value="dash-long" /> <!-- 6-2 -->
|
---|
94 | <xsd:pattern value="dash-medium" /> <!-- 4-4 -->
|
---|
95 | <xsd:pattern value="dash-short" /> <!-- 2-6 -->
|
---|
96 | <xsd:pattern value="dot-sparse" /> <!-- 1-4 -->
|
---|
97 | <xsd:pattern value="dot-normal" /> <!-- 1-2 -->
|
---|
98 | <xsd:pattern value="dot-dense" /> <!-- 1-1 -->
|
---|
99 | <xsd:pattern value="dash-dot" /> <!-- 4-2-1-2 -->
|
---|
100 | <xsd:pattern value="dash-dot-dot" /> <!-- 4-2-1-2-1-2 -->
|
---|
101 | </xsd:restriction>
|
---|
102 | </xsd:simpleType>
|
---|
103 | </schema>
|
---|