A group of javascript modules to make creating user interfaces simpler You can use jsdelivr.net to get the latest modules. For example the module generic_map.js can be accessed in your javascript with
import { setup_generic_map } from "https://cdn.jsdelivr.net/gh/vytools/vyjs@v4.0.4/js/generic_map.js";
generic_map.js uses zoom_pan_canvas.js to create a two dimensional grid and render objects defined in a DRAW_DATA object. These objects can be one of several types including "polygon", "circle", "text", "image", or "arc". The DRAW_DATA object does not have a specific format requirement. The object is searched recursively for sub-objects that have a "draw_type" field that matches one of the types listed above. Here is a simple example of an html file that might use generic_map.js
<html>
<head>
<meta content="text/html;charset=utf-8" http-equiv="Content-Type">
<meta content="utf-8" http-equiv="encoding">
<style>.full {width:100%; height:100%;}</style>
</head>
<body class="full">
<div id="map" class="full" onresize="resizex()"></div>
</body>
<script type="module">
import { setup_generic_map } from "/generic_map.js";
var img1 = new Image();
img1.src = '';
let DRAW_DATA = [
{draw_type:'polygon', points:[{x:300,y:0},{x:400,y:0},{x:400,y:200}],circles:{radius:3,scale_with_zoom:true,color:'lime'},fill:'red',stroke:'rgba(0,0,0,0.5)'},
{draw_type:'polygon', points:[{x:0,y:0},{x:200,y:0},{x:200,y:200}],fill:'red',stroke:'rgba(0,0,0,0.5)'},
{draw_type:'circle', x:-200, y:-200, radius:10, fill:'red',stroke:'rgba(0,0,0,0.5)'},
{draw_type:'circle', x:-230, y:-200, radius:10, fill:'green',stroke:'rgba(0,0,0,0.5)', scale_with_zoom:true},
{draw_type:'text',x:200,y:-200,fill_text:'hi',font:'30px Arial',fill:'red',align:'center'},
{draw_type:'text',x:200,y:-250,fill_text:'hi',font:'30px Arial',fill:'green',align:'center', scale_with_zoom:true},
{draw_type:'image', x:-200, y:200, w:100, h:100, rotation:1.57, image:img1},
{draw_type:'arc', x0:400, y0:-300, q0:Math.PI*4/2, k:0.01, L:100, stroke:'blue', stroke_width:2}
];
let DRAW_EXT = {};
let MAPDIV = document.querySelector('#map');
let MAPFUNCS = setup_generic_map(MAPDIV, DRAW_DATA, DRAW_EXT);
window.resizex = function(event) { if (MAPFUNCS) MAPFUNCS.resize(); }
</script>
</html>In addition custom draw_types can be defined. For example:
<html>
<head>
<meta content="text/html;charset=utf-8" http-equiv="Content-Type">
<meta content="utf-8" http-equiv="encoding">
<style>.full {width:100%; height:100%;}</style>
</head>
<body class="full">
<div id="map" class="full" onresize="resizex()"></div>
</body>
<script type="module">
import { setup_generic_map } from "/generic_map.js";
let DRAW_DATA = [
{draw_type:'special_circle',xx:100,yy:-100}
];
let DRAW_EXT = {
special_circle:function(obj,ctx) {
let trnsfrm = ctx.get_transform();
ctx.lineWidth = 1/trnsfrm.a;
ctx.strokeStyle = 'black';
ctx.beginPath();
ctx.arc(obj.xx, obj.yy, 10/trnsfrm.a, 0, 2 * Math.PI, false);
ctx.stroke();
let fontsize = Math.max(1,Math.floor(12/trnsfrm.a));
console.log(fontsize)
ctx.font = fontsize + 'px Courier';
ctx.textAlign = 'left';
ctx.fillStyle = 'black';
ctx.scale(1,-1);
ctx.fillText('Special!',obj.xx,-obj.yy)
ctx.scale(1,-1);
}
};
let MAPDIV = document.querySelector('#map');
let MAPFUNCS = setup_generic_map(MAPDIV, DRAW_DATA, DRAW_EXT);
window.resizex = function(event) { if (MAPFUNCS) MAPFUNCS.resize(); }
</script>
</html>Finally, the visibility of the sub-objects can be made to toggle on off
<html>
<head>
<meta content="text/html;charset=utf-8" http-equiv="Content-Type">
<meta content="utf-8" http-equiv="encoding">
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
<style>.full {width:100%; height:100%;}</style>
</head>
<body class="full">
<div id="map" class="full" onresize="resizex()"></div>
</body>
<script type="module">
import { setup_generic_map } from "/generic_map.js";
let DRAW_DATA = [
{
draw_toggle:'circleA',
x:{draw_type:'circle',fill:'blue',x:100,y:-100,radius:100,stroke:'black',stroke_width:1}
},
{
draw_toggle:'circleB',
_draw_toggle_off_:true,
somestuff:[
{draw_type:'circle',fill:'red',x:100,y:-300,radius:100,stroke:'black',stroke_width:5},
{draw_type:'circle',fill:'purple',x:300,y:-300,radius:100,stroke:'black',stroke_width:5,scale_with_zoom:true}
]
}
];
let MAPDIV = document.querySelector('#map');
let MAPFUNCS = setup_generic_map(MAPDIV, DRAW_DATA, DRAW_EXT);
window.resizex = function(event) { if (MAPFUNCS) MAPFUNCS.resize(); }
</script>
</html>Tools for resizable divs, use the <flex>, <flexitem> and <flexresizer> tags along with the "display:flex" style properties
<html>
<head>
<meta content="text/html;charset=utf-8" http-equiv="Content-Type">
<meta content="utf-8" http-equiv="encoding">
<link rel="stylesheet" href="/flex.css">
<script type="text/javascript" src="/flex.js" defer></script>
<style>.full {width:100%; height:100%;}</style>
</head>
<body class="full">
<div class="full" style="display:flex;">
<flex class="h full">
<flexitem class="full" style="flex: 1;min-width:300px;overflow: auto;">
<flex class="v full">
<flexitem class="full" style="flex: 1;">
<h1>hey der bub</h1>
</flexitem>
<flexresizer></flexresizer>
<flexitem class="full" style="flex: 3;">
<h1>hey der bub agin</h1>
</flexitem>
</flex>
</flexitem>
<flexresizer></flexresizer>
<flexitem class="full" style="flex: 3;">
<h1>O hi</h1>
</flexitem>
</flex>
</div>
</body>
</html>In progress...
Copy of plotly js
In progress...