UNPKG

agentscript

Version:

AgentScript Model in Model/View architecture

45 lines (37 loc) 1.36 kB
<html> <head> <title>wallFollower</title> </head> <body> <script type="module"> import * as util from 'https://code.agentscript.org/src/utils.js' import Color from 'https://code.agentscript.org/src/Color.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/WallFollowerModel.js' const wallsColor = Color.typedColor(222, 184, 135) const backgroundColor = Color.typedColor('black') const drawOptions = { patchesColor: p => p.breed.name === 'walls' ? wallsColor : backgroundColor, turtlesShape: 'dart', turtlesSize: 2, turtlesColor: t => (t.breed.name === 'lefty' ? 'green' : 'red'), } const model = new Model() await model.startup() model.setup() const view = new TwoDraw(model, { div: 'modelDiv' }, drawOptions) const anim = new Animator( () => { model.step() view.draw() }, 500, // run 500 steps 10 // 10fps, 30fps way too fast! ) util.toWindow({ util, model, view, anim }) </script> <div id="modelDiv"></div> </body> </html>