-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathViz1.html
61 lines (60 loc) · 2.82 KB
/
Viz1.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
<!doctype html>
<html>
<head>
<title>Part 3 Vega-Lite Viz1</title>
<meta charset="utf-8" />
<!-- Include Vega, Vega-Lite, and Vega-Embed scripts from CDN for rendering the visualization -->
<script src="https://cdn.jsdelivr.net/npm/[email protected]"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]"></script>
<!-- Inline CSS to add spacing between Vega-Embed action links -->
<style media="screen">
.vega-actions a {
margin-right: 5px;
}
</style>
</head>
<body>
<!-- Container for the Vega-Lite visualization -->
<div id="vis"></div>
<script>
// JavaScript code to define the visualization specification
var vlSpec = {
"$schema": "https://vega.github.io/schema/vega-lite/v5.15.1.json", // Vega-Lite schema URL
"title": "Group 11", // We Are Group 11 ^_________________^
"data": {"url": "https://raw.githubusercontent.com/sheriefAbdallah/CS318/main/Transactions-smaller.csv"}, // Data source URL
"config": {"view": {"continuousWidth": 300, "continuousHeight": 300}}, // Configuration for view size
"vconcat": [ // Vertical concatenation of two visualizations
{
"mark": {"type": "point"}, // First visualization: scatter plot
"encoding": {
"color": {"field": "property_type_en", "type": "nominal"}, // Color encoding by property type
"x": {"field": "rent_value", "type": "quantitative", "aggregate": "average"}, // X-axis encoding with average rent value
"y": {"field": "meter_rent_price", "type": "quantitative"}, // Y-axis encoding with meter rent price
},
"transform": [
{"filter": "datum.meter_rent_price < 50000"}, // Filter to limit meter rent price
{"filter": "datum.rent_value < 10000000"} // Filter to limit rent value
],
"selection": {
"mySelection": {"type": "interval", "encodings": ["y"]} // Interactive selection on the Y-axis
}
},
{
"mark": {"type": "bar"}, // Second visualization: bar chart
"encoding": {
"color": {"field": "property_type_en", "type": "nominal"}, // Color encoding by property type
"x": {"aggregate": "count", "type": "quantitative"}, // X-axis encoding with count aggregation
"y": {"field": "property_type_en", "type": "nominal"}, // Y-axis encoding with property type
},
"transform": [
{"filter": {"selection": "mySelection"}} // Filter based on the selection from the first visualization
]
}
],
}
// Embed the visualization in the container with id `vis` using the Vega-Embed library
vegaEmbed('#vis', vlSpec);
</script>
</body>
</html>