Skip to content

vytools/vyjs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

84 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

vyjs

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

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>

flex.js and flex.css

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>

mousefollower.js

In progress...

plotly-X.XX.min.js

Copy of plotly js

definition_form.js definition_form.css

In progress...

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 2

  •  
  •