d2/lib/shape/shape_stored_data.go

67 lines
1.9 KiB
Go
Raw Normal View History

package shape
import (
"oss.terrastruct.com/d2/lib/geo"
"oss.terrastruct.com/d2/lib/svg"
)
type shapeStoredData struct {
*baseShape
}
const storedDataWedgeWidth = 15.
func NewStoredData(box *geo.Box) Shape {
return shapeStoredData{
baseShape: &baseShape{
Type: STORED_DATA_TYPE,
Box: box,
},
}
}
func (s shapeStoredData) GetInnerBox() *geo.Box {
width := s.Box.Width
tl := s.Box.TopLeft.Copy()
width -= 2 * storedDataWedgeWidth
tl.X += storedDataWedgeWidth
return geo.NewBox(tl, width, s.Box.Height)
}
func storedDataPath(box *geo.Box) *svg.SvgPathContext {
wedgeWidth := storedDataWedgeWidth
multiplier := 0.27
if box.Width < wedgeWidth*2 {
wedgeWidth = box.Width / 2.0
}
pc := svg.NewSVGPathContext(box.TopLeft, 1, 1)
pc.StartAt(pc.Absolute(wedgeWidth, 0))
pc.H(true, box.Width-wedgeWidth)
pc.C(false, box.Width-wedgeWidth*multiplier, 0, box.Width-wedgeWidth, box.Height*multiplier, box.Width-wedgeWidth, box.Height/2.0)
pc.C(false, box.Width-wedgeWidth, box.Height-box.Height*multiplier, box.Width-wedgeWidth*multiplier, box.Height, box.Width, box.Height)
pc.H(true, -(box.Width - wedgeWidth))
pc.C(false, wedgeWidth-wedgeWidth*multiplier, box.Height, 0, box.Height-box.Height*multiplier, 0, box.Height/2.0)
pc.C(false, 0, box.Height*multiplier, wedgeWidth-wedgeWidth*multiplier, 0, wedgeWidth, 0)
pc.Z()
return pc
}
func (s shapeStoredData) Perimeter() []geo.Intersectable {
return storedDataPath(s.Box).Path
}
func (s shapeStoredData) GetSVGPathData() []string {
return []string{
storedDataPath(s.Box).PathData(),
}
}
func (s shapeStoredData) GetDimensionsToFit(width, height, paddingX, paddingY float64) (float64, float64) {
totalWidth := width + paddingX + 2*storedDataWedgeWidth
return totalWidth, height + paddingY
}
2023-01-24 03:10:31 +00:00
func (s shapeStoredData) GetDefaultPadding() (paddingX, paddingY float64) {
return defaultPadding - 10, defaultPadding
}