예제 #1
0
파일: draw.go 프로젝트: ebering/zellij
func (m *Map) DrawEdges(ctx *cairo.Surface) {
	m.Edges.Do(func(f interface{}) {
		e, _ := f.(*Edge)
		e.Line().Draw(ctx)
	})
	m.Verticies.Do(func(v interface{}) {
		ctx.SetSourceRGBA(0., 0., 0., 1.)
		v.(*Vertex).Draw(ctx)
	})
}
예제 #2
0
파일: draw.go 프로젝트: ebering/zellij
func (m *Map) DrawDebugEdges(ctx *cairo.Surface) {
	m.Edges.Do(func(f interface{}) {
		e, _ := f.(*Edge)
		ctx.SetSourceRGBA(0., float64((e.Generation*20)%255)/255., 0., 1.)
		e.Line().Draw(ctx)
	})
	m.Verticies.Do(func(v interface{}) {
		ctx.SetSourceRGBA(0., 0., 0., 1.)
		v.(*Vertex).Draw(ctx)
	})
}
예제 #3
0
파일: draw.go 프로젝트: ebering/zellij
func (m *Map) ColourFaces(ctx *cairo.Surface, brush func(*Face) (float64, float64, float64, float64)) {
	m.Faces.Do(func(f interface{}) {
		F := f.(*Face)
		ctx.SetSourceRGBA(brush(F))
		e := F.boundary
		ctx.MoveTo(e.start.Float64())
		for f := e.Next(); f != e; f = f.Next() {
			ctx.LineTo(f.start.Float64())
		}
		ctx.ClosePath()
		ctx.Fill()
	})
}
예제 #4
0
파일: draw.go 프로젝트: ebering/zellij
func (l *Line) DrawEndpoints(ctx *cairo.Surface) {
	ctx.MoveTo(l.start.Float64())
	ctx.LineTo(l.end.Float64())
	ctx.Stroke()
	l.start.Draw(ctx)
	l.end.Draw(ctx)
}
예제 #5
0
파일: draw.go 프로젝트: ebering/zellij
func (p *Point) Draw(ctx *cairo.Surface) {
	ctx.Arc(p.x.Float64(), p.y.Float64(), .1, 0., 2.*math.Pi)
	ctx.Fill()
}
예제 #6
0
파일: draw.go 프로젝트: ebering/zellij
func (m *Map) ColourDebugFaces(ctx *cairo.Surface) {
	n := float64(m.Faces.Len())
	i := 0.
	m.Faces.Do(func(f interface{}) {
		F, _ := f.(*Face)
		if F.Value.(string) == "outer" {
			return
		}
		e := F.boundary
		ctx.MoveTo(e.start.Float64())
		for f := e.Next(); f != e; f = f.Next() {
			ctx.LineTo(f.start.Float64())
		}
		ctx.ClosePath()
		if F.Value.(string) == "skeleton" {
			ctx.SetSourceRGBA(0., 0., 1., 1.)
		} else {
			ctx.SetSourceRGBA(i/n, 0., 0., 1.)
		}
		ctx.Fill()
		i = i + 1.
	})
}