module Cell where
import Graphics.Gloss
data Cell
= Cell Point -- centre
Float -- radius
Int
deriving Show
-- Produce a new cell of a certain relative radius at a certain angle.
-- The factor argument is in the range [0..1] so spawned cells are
-- smaller than their parent.
-- The check whether it fits in the community is elsewhere.
offspring :: Cell -> Float -> Float -> Cell
offspring (Cell (x,y) r gen) alpha factor
= Cell (x + (childR+r) * cos alpha, y + (childR+r) * sin alpha)
childR
(gen + 1)
where childR = factor * r
-- Do two cells overlap?
-- Used to decide if newly spawned cells can join the community.
overlap :: Cell -> Cell -> Bool
overlap (Cell (x1,y1) r1 _) (Cell (x2,y2) r2 _)
= centreDist < (r1 + r2) * 0.999
where centreDist = sqrt(xdiff*xdiff + ydiff*ydiff)
xdiff = x1 - x2
ydiff = y1 - y2
render :: Cell -> Picture
render (Cell (x,y) r gen)
= let z = fromIntegral gen * 0.1
color = makeColor 0.0 z 0.5 1.0
in Color color
$ Translate x y
$ Circle r