Use transformations in svg context
also few minor changes in to svg transformation functions
This commit is contained in:
parent
6d31bfac59
commit
215a761ccb
3 changed files with 57 additions and 33 deletions
|
@ -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],
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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"`
|
||||||
|
|
Loading…
Reference in a new issue