-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.html
157 lines (134 loc) · 6.13 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
<!--
This is an experiment in non-mouse map navigation made in the Esri R&D Center DC.
It was fun!
Peter Richardson July 2021
pxrich@gmail.com
-->
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta
name="viewport"
content="initial-scale=1,maximum-scale=1,user-scalable=no"
/>
<title>Esri Music Map Demo</title>
<link href="tabnav-min.css" rel="stylesheet">
<script src='https://unpkg.com/tone@14.7.77/build/Tone.js'></script>
<!-- 3rd party libraries -->
<script src="https://d3js.org/d3.v4.js"></script>
<!-- <script src="https://cdn.rawgit.com/fabid/d3-rectbin/master/rectbin.js"></script> -->
<script src="rectbin.js"></script> <!-- local for debugging -->
<script type="module" src="sonar.mjs"></script>
</head>
<body>
<div id="header"><div class="title">Music Map</div>
<div class="subtitle"><a href="https://github.com/esridc/music-map">https://github.com/esridc/music-map</a></div>
</div>
<div id="content">
<div id="keyboardModeMenu" tabindex="0" class="sidebar">
<div class="sidebarItems">
<h1>Menu,</h1>
<ul role="list">
<li role="listitem">
<input type="checkbox" tabindex="0" id="featureSelectionModeButton" aria-labelledby="featureSelectionModeLabel"></input>
<label id="featureSelectionModeLabel">Feature Selection,</label>
</li>
<li role="listitem">
<input type="checkbox" tabindex="0" id="featureModeButton" aria-labelledby="featureModeLabel"></input>
<label id="featureModeLabel">Inspect Feature,</label>
</li>
<li role="listitem">
<input type="checkbox" tabindex="0" id="verboseCheckbox" aria-labelledby="verboseLabel"></input>
<label id="verboseLabel">Verbose,</label>
</li>
<li role="listitem">
<input type="checkbox" tabindex="0" id="sonarModeCheckbox" aria-labelledby="sonarModeLabel"></input>
<label id="sonarModeLabel">Sound,</label>
</li>
<li role="listitem">
<input type="checkbox" tabindex="0" id="helpButton" aria-labelledby="helpButtonLabel"></input>
<label id="helpButtonLabel">Help,</label>
</li>
<li role="listitem">
<button tabindex="0" id="pingButton" onclick="triggerPing()">PLAY</button>
</li>
</ul>
</div>
</div>
<div id="status">
<div>
Focus:
<span id="focusStatus">focusStatus</span>
</div>
<div>
Key:
<span id="keyStatus">keyStatus</span>
</div>
<div>
Mode:
<span id="modeStatus">modeStatus</span>
</div>
</div>
<div id="alertDivWrapper">
Speech announcement
<div id="alertDiv" role="alert">
</div>
</div>
<div id="helpDivWrapper">
<div id="helpDiv" role="alert" tabindex="0">
<h2 tabindex="0">Music Map Help</h2>
<p tabindex="0" role="text">You can tab through this message.</p>
<p tabindex="0" role="text">Press escape to close this message and go to the main menu.</p>
<p tabindex="0" role="text">To disable sounds, uncheck the "Sounds" button.</p>
<p tabindex="0" role="text">This map uses non-visual navigation, and is designed for use with screen readers. It shows 2000 global features from a water quality database, and starts centered on the Iberian Peninsula over Madrid.</p>
<p tabindex="0" role="text">The arrow keys move the map. 'Z' and 'X' to zoom in and out. 'C' to center and zoom in on a selected feature.</p>
<p tabindex="0" role="text">The number keys also set zoom levels 0 through 9. Zoom 0 shows the whole world, zoom 6 is roughly the size of a country, zoom 12 is city level, and zoom 16 shows individual streets.</p>
<p tabindex="0" role="text">There is a menu with five options. Pressing enter on each will toggle the selected mode.</p>
<div role ="list">
<p tabindex="0" role="text">1, Feature selection. In this mode, press Tab and Shift-tab to move forward and back through onscreen features. Press Enter to examine a selected feature's data. Press escape to exit selection mode and return to the menu.</p>
<p tabindex="0" role="text">2, Inspect feature. In this mode, press Tab and Shift-tab to move forward and back through a selected feature's attributes. Press escape to leave the feature and return to selection mode.</p>
<p tabindex="0" role="text">3, Verbose. This mode announces zoom levels and a geolocation result for the area in the center of the map.</p>
<p tabindex="0" role="text">4, Sound. This mode plays musical notes when the map moves. The onscreen features are converted to a musical score from west to east, with vertical screen position converted to pitch. When this mode is active, individual features will be played in Feature selection mode. You may also press "s" to play at any time.</p>
<p tabindex="0" role="text">5, Help. This button shows this help text. Press escape to return to the main menu.</p>
<p>End of help.</p>
</div>
</ul>
</div>
</div>
<!-- popup content template -->
<div style="position: absolute; visibility: hidden" id="popup-content-template" tabindex="0">
<table id="popupTable">
<p role="heading "tabindex="0">
<p id="placeLabel" role="heading"></p> <!-- needs a tabindex so it can be .focus()ed -->
<p id="attributeCount"></p>
</p>
<thead>
<tr>
<th>Attribute Name</th>
<th>Attribute Value</th>
</tr>
</thead>
</table>
</div>
<div id="viewDiv" tabindex="0" aria-label="Map">
<div id="loaderWrapper">
<div id="base-loader" aria-label="loading">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 56 56" class="loader-square loader-square-1">
<rect width="56" height="56"></rect>
</svg>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 56 56" class="loader-square loader-square-2">
<rect width="56" height="56"></rect>
</svg>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 56 56" class="loader-square loader-square-3">
<rect width="56" height="56"></rect>
</svg>
<div class="loader-bars"></div>
</div>
</div>
</div>
</div>
</div>
</div>
</body>
</html>