UNPKG

agentscript

Version:

AgentScript Model in Model/View architecture

58 lines (49 loc) 1.52 kB
<html> <head> <title>fire</title> <link rel="icon" type="image/x-icon" href="../favicon.ico" /> </head> <body> <script type="module"> import * as util from '../src/utils.js' import ThreeDraw from '../src/ThreeDraw.js' import Color from '../src/Color.js' import Model from '../models/FireModel.js' const typeColors = { dirt: Color.cssToPixel('yellow'), tree: Color.cssToPixel('green'), fire: Color.cssToPixel('red'), ember4: Color.rgbaToPixel(255 - 25, 0, 0), ember3: Color.rgbaToPixel(255 - 50, 0, 0), ember2: Color.rgbaToPixel(255 - 75, 0, 0), ember1: Color.rgbaToPixel(255 - 100, 0, 0), ember0: Color.rgbaToPixel(255 - 125, 0, 0), } const drawOptions = { patchesColor: p => typeColors[p.type], } async function run() { const model = new Model() await model.startup() model.setup() const view = new ThreeDraw( model, { div: 'modelDiv' }, drawOptions ) util.toWindow({ util, model, view }) await util.timeoutLoop( () => { model.step() view.draw() }, 500, 33 ) view.idle() } run() </script> <div id="modelDiv"></div> </body> </html>