-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
174 lines (151 loc) · 4.45 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
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
<html>
<head>
<meta charset="UTF-8">
<meta name="description"
content="fast and scalable WebGL2 based rendering library for visualizing scatter/dot plots.">
<meta name="keywords" content="WebGL2, scatter plot, tsne, umap, WebWorker, OffScreenCanvas">
<meta name="author" content="Jayaram Kancherla">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
font-family: "Lucida Sans", "Lucida Sans Regular", "Lucida Grande",
"Lucida Sans Unicode", Geneva, Verdana, sans-serif;
}
.app {
display: grid;
grid-template-columns: 40% 60%;
grid-template-rows: auto auto auto;
gap: 10px;
}
.content {
grid-row: 2 / -1;
grid-column: 1;
padding: 10px;
}
.canvas {
grid-row: 2;
grid-column: 2;
height: 500px;
width: 500px;
border: 1px solid black;
margin: 40px;
}
.header {
grid-row: 1;
grid-column: 1 / -1;
text-align: center;
padding: 4px;
}
.console {
grid-row: 3;
grid-column: 2;
min-height: 100px;
max-height: 175px;
overflow-y: auto;
margin: 20px;
padding: 10px;
background-color: gainsboro;
line-height: 0.1;
}
</style>
</head>
<body>
<div class="app">
<div class="header">
<h4>epiviz.scatter.gl</h4>
<p>this dataset contains 150k points (comes from <a
href="https://github.com/genome-spy/website-examples/tree/master/tSNE" target="_blank">genome-spy</a>,
not the fanciest demo page but it works :) </p>
</div>
<div class="content">
<h4>Simple Usage:</h4>
<pre>
import ScatterGL from "epiviz.scatter.gl";
# you can either pass in a dom selector or HTMLElement
let plot = new ScatterGL(".canvas");
# provide input data to the element,
# data must contain x and y coordinates
plot.setInput({
x: [...],
y: [...],
});
# render the plot
plot.render();
</pre>
<h4>Capture events:</h4>
<p>The library provides click, hover (mouseover) and selection events
for interactivity with the plot. The default behavior logs the
events to the console</p>
<pre>
plot.hoverCallback = function(point) {
# do something when a point is hovered
console.log(point);
}
</pre>
<h4>Interactions:</h4>
<p>currently supports
<ul>
<li>pan: for pan/zoom operations on canvas</li>
<li>box: box selection of data points</li>
<li>lasso: lasso selection</li>
</ul>
</p>
<pre>
plot.setInteraction("lasso");
</pre>
<p>For more documentation, visit
<a href="https://github.com/jkanche/epiviz.scatter.gl">GitHub</a> repository
</p>
</div>
<div class="canvas">
<button class="canvas-pan">pan</button>
<button class="canvas-box">box</button>
<button class="canvas-lasso">lasso</button>
</div>
<div class="console">
<p>(closest point wrt to mouse)</p>
</div>
</div>
<script type="module">
import ScatterGL from "./index.js";
import { data, color } from './data.js';
let plot = new ScatterGL(".canvas");
plot.setInput(data);
plot.hoverCallback = function (point) {
if (point) {
if (point.distance <= 1.5) {
let tnode = document.createElement("p");
tnode.textContent = `Hover (closest point): ${point.indices[0]}`
document
.querySelector(".console")
.prepend(tnode);
}
}
};
plot.selectionCallback = function (points) {
if (points) {
let tnode = document.createElement("p");
tnode.textContent = `Selection: ${points.selection.indices.length} points`
document
.querySelector(".console")
.prepend(tnode);
}
};
plot.setState({
"size": 1,
color,
"opacity": 0.7
});
plot.render();
document.querySelector(".canvas-box").addEventListener("click", () => {
plot.setInteraction("box");
});
document.querySelector(".canvas-pan").addEventListener("click", () => {
plot.setInteraction("pan");
});
document.querySelector(".canvas-lasso").addEventListener("click", () => {
plot.setInteraction("lasso");
});
</script>
</body>
</html>