# litegraph.js **Repository Path**: qkzztx_admin/litegraph.js ## Basic Information - **Project Name**: litegraph.js - **Description**: litegraph.jslitegraph.jslitegraph.js - **Primary Language**: Java - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1 - **Created**: 2024-01-31 - **Last Updated**: 2024-01-31 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # litegraph.js A library in Javascript to create graphs in the browser similar to [PureData](https://puredata.info/). Nodes can be programmed easily and it includes an editor to construct the graphs. It can be integrated easily in any existing web applications and graphs can be run without the need of the editor. ![Node Graph](imgs/node_graph_example.PNG "WebGLStudio") ## Installation You can install it using npm ``` npm install litegraph.js ``` Or downloading the ```build/litegraph.js``` version from this repository. ## First project ## ```html ``` ## How to code a new Node type Here is an example of how to build a node that sums two inputs: ```javascript //node constructor class function MyAddNode() { this.addInput("A","number"); this.addInput("B","number"); this.addOutput("A+B","number"); } //name to show MyAddNode.title = "Sum"; //function to call when the node is executed MyAddNode.prototype.onExecute = function() { var A = this.getInputData(0); if( A === undefined ) A = 0; var B = this.getInputData(1); if( B === undefined ) B = 0; this.setOutputData( 0, A + B ); } //register in the system LiteGraph.registerNodeType("basic/sum", MyAddNode ); ``` or you can wrap an existing function: ```js function sum(a,b) { return a+b; } LiteGraph.wrapFunctionAsNode("math/sum",sum, ["Number","Number"],"Number"); ``` ## Server side It also works server-side using Node although some nodes do not work in server (audio, graphics, input, etc). ```js var LiteGraph = require("./litegraph.js").LiteGraph; var graph = new LiteGraph.LGraph(); var node_time = LiteGraph.createNode("basic/time"); graph.add(node_time); var node_console = LiteGraph.createNode("basic/console"); node_console.mode = LiteGraph.ALWAYS; graph.add(node_console); node_time.connect( 0, node_console, 1 ); graph.start() ``` ## Projects using it ### [webglstudio.org](http://webglstudio.org) ![WebGLStudio](imgs/webglstudio.gif "WebGLStudio") ### [MOI Elephant](http://moiscript.weebly.com/elephant-systegraveme-nodal.html) ![MOI Elephant](imgs/elephant.gif "MOI Elephant") ### [Mynodes.NET](http://www.mynodes.net) ![MyNodes.NET](imgs/mynodes.png "MyNodes.NET") ## Utils ----- It includes several commands in the utils folder to generate doc, check errors and build minifyed version. ## Feedback -------- You can write any feedback to javi.agenjo@gmail.com ## Contributors - kriffe