LogoMor
LogoMor is a JavaScript interpreter and visualizer for the Logo programming language
Technologies
The interpreter is written in vanilla JavaScript
UI in HTML5 and CSS3
p5.js and WebGL are used for 3D rendering
Code editor uses CodeMirror with custom mode for the Logo language
Logo language
The interpreter accepts the basic UCBLogo commands with many additions:
- 3-Dimentional moves
- Random number generator (per run and per frame modes available)
- Timing commands, returning current time and frame
- Static variables with not frame-limited lifetime
- Mouse movements tracking commands
- Face creation commands for making surfaces as solid objects faces
Usage - Features
- The web interface provides tools for editing, running and debugging Logo code
- The output 3D drawing is visualized on a canvas and can be manipulated with the mouse to rotate, pan or zoom. Active perspective and lighting
- The whole Logo program is interpreted and produces a drawing for each display frame. Default frame rate is 60 fps, but this is affected by the program size. Fps indication on screen to help determining execution load.
- Pause mode is available, that executes the code only once and produces a still image
- For each global variable of the program, a 'variable manipulator' is automatically generated. The user can enable it and use a slider to manipulate the variables initial value while watching its effect on the drawing in real time
- Using timing commands and static variables, the programmer can create any kind of animation
- Mouse tracking commands enable the creation of interactive sketches
- Solid objects can be created easily by drawing faces with the plain movement commands to indicate edges
- The user can check various pre-loaded demos by pressing the 'Demo' button
- Complete documentation about all supported commands and Logo syntax is available by pressing the 'Help' button
- The programmer can run the program partially or step-by-step by using the 'Moves Limit' field
- If an execution error occurs, a verbose error message will be shown on the console, including error line number and a complete stack trace
- The user can capture snapshots or video of the drawing
- The user can save the Logo code to plain text or load a file from the filesystem. Drag and drop is also supported
- The drawing can be viewed in auto-rotating mode
- The user can enable an orientation and turning assistant that is displayed on the drawing avatar to help during programming
- The editor has many IDE features as auto-completion, auto-indentation, keyword highlighting (also distinguishing plain commands from move commands), search highlighting, auto bracket closing etc
Contributing
I would love to receive any LogoMor sketches and include them to the Demos
Also feel free to submit issues and enhancement requests.
License
from Hacker News https://ift.tt/3qtJ85o
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.