UNPKG

agentscript

Version:

AgentScript Model in Model/View architecture

57 lines (46 loc) 1.66 kB
<html> <head> <title>flock</title> </head> <body> <script type="module"> import * as util from 'https://code.agentscript.org/src/utils.js' import TwoDraw from 'https://code.agentscript.org/src/TwoDraw.js' import Animator from 'https://code.agentscript.org/src/Animator.js' import Model from 'https://code.agentscript.org/models/FlockModel.js' import dat from 'https://code.agentscript.org/vendor/dat.gui.js' // ============================== const model = new Model() await model.startup() model.setup() const view = new TwoDraw(model, { div: 'modelDiv', width: 500, }) // defalt drawOptions! const anim = new Animator( () => { model.step() view.draw() }, 500, // run 500 steps 30 // 30 fps ).startStats() // ============================== const gui = new dat.GUI() gui.add(anim, 'fps', 1, 60, 1).onChange(() => anim.reset()) gui.add(anim, 'toggle') gui.add(anim, 'once') gui.add(model, 'population', 100, 1000, 100).onChange(val => { model.reset() model.setup() }) gui.add(view, 'width', 100, 1000, 25) // gui.add(view.drawOptions, 'turtlesShape', ['bug', 'dart', 'person']) gui.add(view.drawOptions, 'turtlesSize', 1, 10, 1) gui.add(view, 'downloadCanvas') // ============================== util.toWindow({ util, model, view, anim, gui }) </script> <div id="modelDiv"></div> </body> </html>