| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- // package view_link -- отображение связи между объектами
- package view_link
- import (
- svg "github.com/ajstarks/svgo"
- "gitp78su.ipnodns.ru/svi/kern/v3"
- "gitp78su.ipnodns.ru/svi/goarch/lev0/types"
- )
- // ViewLink -- отображение связи между объектами
- type ViewLink struct {
- types.IElemLink
- }
- var (
- hassert = kern.GetFnHassert()
- )
- // NewViewLink -- возвращает новое отображение связи
- func NewViewLink(useLink types.IElemLink) *ViewLink {
- hassert(useLink != nil, "NewViewLink: useLink is nil")
- sf := &ViewLink{
- IElemLink: useLink,
- }
- return sf
- }
- // Draw -- рисует связь между объектами
- func (sf *ViewLink) Draw(canvas *svg.SVG) {
- x, y := sf.Coord().Int()
- x1, y1 := sf.CoordEnd().Int()
- offX, offY := sf.Offset().Int()
- // Линия
- canvas.Line(x, y, x1, y1, "stroke:black;stroke-width:1")
- strLabel := sf.String()
- if strLabel != "" {
- canvas.Text(x+offX, y+offY, strLabel, "font-size: 12px; font-family: Courier; fill: black")
- }
- if sf.TypeLink() != "" {
- canvas.Text(x+offX, y+offY+12, "<<"+sf.TypeLink()+">>", "font-size: 12px; font-family: Courier; fill: black")
- }
- if msgErr := sf.Check(); msgErr != "" { // Проверка на правильность
- canvas.Group("Ошибка")
- canvas.Title(msgErr)
- canvas.Image(x-20+offX, y-20+offY, 16, 16, "/static/img/warning.png")
- }
- canvas.Gend() // Group end
- }
|