Use transformations in svg context

also few minor changes in to svg transformation functions
This commit is contained in:
Drahoslav 2017-12-26 14:25:28 +01:00
parent 6d31bfac59
commit 215a761ccb
3 changed files with 57 additions and 33 deletions

View file

@ -13,7 +13,11 @@ import (
func toSvgRGBA(c color.Color) string { func toSvgRGBA(c color.Color) string {
r, g, b, a := c.RGBA() r, g, b, a := c.RGBA()
return fmt.Sprintf("rgba(%v, %v, %v, %.3f)", r>>8, g>>8, b>>8, float64(a>>8)/255) r, g, b, a = r>>8, g>>8, b>>8, a>>8
if a == 255 {
return fmt.Sprintf("#%02X%02X%02X", r, g, b)
}
return fmt.Sprintf("rgba(%v,%v,%v,%.3f)", r, g, b, float64(a)/255)
} }
func toSvgLength(l float64) string { func toSvgLength(l float64) string {
@ -84,10 +88,7 @@ func toSvgPathDesc(p *draw2d.Path) string {
// rx ry x-axis-rotation large-arc-flag sweep-flag x y // rx ry x-axis-rotation large-arc-flag sweep-flag x y
parts[i] = fmt.Sprintf("A %.4f %.4f %v %v %v %.4f %.4f", parts[i] = fmt.Sprintf("A %.4f %.4f %v %v %v %.4f %.4f",
rx, ry, rx, ry, 0, large, sweep, x, y,
0,
large, sweep,
x, y,
) )
ps = ps[6:] ps = ps[6:]
case draw2d.CloseCmp: case draw2d.CloseCmp:
@ -96,3 +97,16 @@ func toSvgPathDesc(p *draw2d.Path) string {
} }
return strings.Join(parts, " ") return strings.Join(parts, " ")
} }
func toSvgTransform(mat draw2d.Matrix) string {
if mat.IsIdentity() {
return ""
}
if mat.IsTranslation() {
x, y := mat.GetTranslation()
return fmt.Sprintf("translate(%f,%f)", x, y)
}
return fmt.Sprintf("matrix(%f,%f,%f,%f,%f,%f)",
mat[0], mat[1], mat[2], mat[3], mat[4], mat[5],
)
}

View file

@ -70,20 +70,24 @@ func (gc *GraphicContext) FillStroke(paths ...*draw2d.Path) {
} }
func (gc *GraphicContext) drawPaths(drawType drawType, paths ...*draw2d.Path) { func (gc *GraphicContext) drawPaths(drawType drawType, paths ...*draw2d.Path) {
paths = append(paths, gc.Current.Path) // create elements
svgPath := Path{} svgPath := Path{}
group := Group{} group := Group{}
// set attrs to path
{
paths = append(paths, gc.Current.Path)
svgPathsDesc := make([]string, len(paths)) svgPathsDesc := make([]string, len(paths))
// multiple pathes has to be joined to single svg path description // multiple pathes has to be joined to single svg path description
// because fill-rule wont work for whole group // because fill-rule wont work for whole group as excepted
for i, path := range paths { for i, path := range paths {
svgPathsDesc[i] = toSvgPathDesc(path) svgPathsDesc[i] = toSvgPathDesc(path)
} }
svgPath.Desc = strings.Join(svgPathsDesc, " ") svgPath.Desc = strings.Join(svgPathsDesc, " ")
}
// set attrs to group
{
if drawType&stroked == stroked { if drawType&stroked == stroked {
group.Stroke = toSvgRGBA(gc.Current.StrokeColor) group.Stroke = toSvgRGBA(gc.Current.StrokeColor)
group.StrokeWidth = toSvgLength(gc.Current.LineWidth) group.StrokeWidth = toSvgLength(gc.Current.LineWidth)
@ -100,8 +104,11 @@ func (gc *GraphicContext) drawPaths(drawType drawType, paths ...*draw2d.Path) {
group.FillRule = toSvgFillRule(gc.Current.FillRule) group.FillRule = toSvgFillRule(gc.Current.FillRule)
} }
group.Paths = []Path{svgPath} group.Transform = toSvgTransform(gc.Current.Tr)
}
// link elements
group.Paths = []Path{svgPath}
gc.svg.Groups = append(gc.svg.Groups, group) gc.svg.Groups = append(gc.svg.Groups, group)
} }
@ -130,12 +137,14 @@ func (gc *GraphicContext) DrawImage(image image.Image) {
// Save the context and push it to the context stack // Save the context and push it to the context stack
func (gc *GraphicContext) Save() { func (gc *GraphicContext) Save() {
gc.StackGraphicContext.Save()
// TODO use common transformation group for multiple elements
} }
// Restore remove the current context and restore the last one // Restore remove the current context and restore the last one
func (gc *GraphicContext) Restore() { func (gc *GraphicContext) Restore() {
gc.StackGraphicContext.Restore()
// TODO use common transformation group for multiple elements
} }
// ClearRect fills the specified rectangle with a default transparent color // ClearRect fills the specified rectangle with a default transparent color

View file

@ -18,6 +18,7 @@ type Svg struct {
type Group struct { type Group struct {
FillStroke FillStroke
Transform string `xml:"transform,attr,omitempty"`
Groups []Group `xml:"g"` Groups []Group `xml:"g"`
Paths []Path `xml:"path"` Paths []Path `xml:"path"`
Texts []Text `xml:"text"` Texts []Text `xml:"text"`