Files
qt-creator/share/qtcreator/modeleditor/standard.def
Jochen Becher a2de97b1b7 ModelEditor: Define syntax of custom definitions like QML
The new syntax is not exactly QML but very similar.

Change-Id: Id08a73cd26923a146429282809f2a5cc6f201d39
Reviewed-by: Tobias Hunger <tobias.hunger@theqtcompany.com>
2016-01-05 15:02:58 +00:00

336 lines
8.7 KiB
Modula-2

// ModelEditor - definitions of custom shapes
//
// Language syntax and commands:
//
// Icon {
// id: <id>
// title: <a UI title. Defaults to the id of the icon.>
// elements: <comma-separated list of element types the
// definiton applies to: class, component, package, diagram, item.
// Default applies definition to all element types.>
// stereotype: <stereotype as a string.>
// display: <default display of element.
// One of: none, label, decoration, icon, smart.
// Default is smart.>
// width: <width of icon in pixels. The width defines the width of the icon as decoration.>
// height: <height of icon in pixels. The height defines the height of the icon as decoration.>
// minwidth: <minimum width of custom icon in pixels.>
// minheight: <minimum height of custom icon in pixels.>
// lockSize: <lock resizing.
// One of: none, width, height, size, ratio.
// Default is none.>
// textAlignment: <alignment of text.
// One of: top, center, below.
// Defaults to center.>
// baseColor: <color #rrggbb>
// Shape {
// Line { x1: <x1>; y1: <y1>; x2:<x2>; y2: <y2> }
// Rect { x: <x>; y: <y>; width: <width>; height: <height> }
// RoundedRect { x: <x>; y: <y>; width: <width>; height: <height>; radius: <radius> }
// Circle { x: <center_x>; y: <center_y>; radius: <radius> }
// Ellipse { x: <center_x>; y: <center_y>; radiusX: <radius_x>; radiusY: <radius_y> }
// Arc { x: <center_x>; y: <center_y>; radiusX: <radius_x>; radiusY: <radius_y>; start: <start_angle>; span: <span_angle> }
// MoveTo { x: <x>; y: <y> }
// LineTo { x: <x>; y: <y> }
// ArcMoveTo { x: <center_x>; y: <center_y>; radiusX: <radius_x>; radiusY: <radius_y>; angle: <angle> }
// ArcTo { x: <center_x>; y: <center_y>; radiusX: <radius_x>; radiusY: <radius_y>; start: <start_angle>; span: <span_angle> }
// Close
// }
// }
//
// Toolbar {
// id: <id>
// title: <a Ui title. Defaults to the id of the toolbar>
// priority: <priority number which decides about the position of toolbar in toolbox. Defaults to 0>
// Tools {
// Tool { title: <Ui title>; element: <element type>; stereotype: <stereotype, defaults to nothing> }
// Separator
// }
// }
//
// *************
// ** Classes **
// *************
Icon {
id: Interface
elements: class
stereotype: 'interface'
display: icon
width: 20.0
height: 20.0
lockSize: ratio
Shape {
Circle { x: 10.0; y: 10.0; radius: 10.0 }
}
}
Icon {
id: Boundary
stereotype: 'boundary'
width: 24.0
height: 20.0
lockSize: ratio
Shape {
Circle { x: 14.0; y: 10.0; radius: 10.0 }
Line { x0: 0.0; y0: 0.0; x1: 0.0; y1: 20.0 }
Line { x0: 0.0; y0: 10.0; x1: 4.0; y1: 10.0 }
}
}
Icon {
id: Control
stereotype: 'control'
width: 20.0
height: 20.0
lockSize: ratio
Shape {
Circle { x: 10.0; y: 10.0; radius: 10.0 }
Line { x0: 10.0; y0: 0.0; x1: 14.0; y1: -2.0 }
Line { x0: 10.0; y0: 0.0; x1: 14.0; y1: 4.0 }
}
}
Icon {
id: Entity
stereotype: 'entity'
width: 20.0
height: 20.0
lockSize: ratio
Shape {
Circle { x: 10.0; y: 10.0; radius: 10.0 }
Line { x0: 0.0; y0: 20.0; x1: 20.0; y1: 20.0 }
}
}
// ****************
// ** Components **
// ****************
Icon {
id: Database
stereotype: 'database'
display: icon
width: 20.0
height: 20.0
Shape {
MoveTo { x: 0.0; y: 3.0 }
LineTo { x: 0.0; y: 17.0 }
ArcTo { x: 10.0; y: 17.0; radiusX: 10.0; radiusY: 3.0; start: 180.0; span: 180.0 }
LineTo { x: 20.0; y: 3.0 }
ArcTo { x: 10.0; y: 3.0; radiusX: 10.0; radiusY: 3.0; start: 0.0; span: -180.0 }
Close
Arc { x: 10.0; y: 3.0; radiusX: 10.0; radiusY: 3.0; start: 0.0; span: 180.0 }
}
}
// experimental replacement of default shape with custom shape
Icon {
id: Component
elements: component, package, diagram
stereotype: 'component'
display: decoration
width: 20.0
height: 16.0
textAlignment: center
Shape {
Rect { x: 0; y: 0; width: 20.0; height: 16.0 }
Rect { x: -4.0; y: 2.5; width: 8; height: 4 }
Rect { x: -4.0; y: 9.5; width: 8; height: 4 }
}
}
// ***************
// ** Use Cases **
// ***************
Icon {
id: UseCase
Title: "Use-Case"
elements: item
stereotype: 'usecase'
display: icon
width: 40
height: 20
baseColor: #5fb4f0
Shape {
Ellipse { x: 20; y: 10; radiusX: 20; radiusY: 10 }
}
}
Icon {
id: Actor
elements: item
stereotype: 'actor'
display: icon
width: 20
height: 40
lockSize: ratio
baseColor: #5fb4f0
Shape {
Circle { x: 10; y: 5; radius: 5 }
Line { x0: 0; y0: 15; x1: 20; y1: 15 }
Line { x0: 10; y0: 10; x1: 10; y1: 25 }
Line { x0: 10; y0: 25; x1: 3; y1: 40 }
Line { x0: 10; y0: 25; x1: 17; y1: 40 }
}
}
// ****************
// ** Activities **
// ****************
Icon {
id: Start
elements: item
stereotype: 'start'
display: icon
width: 20
height: 20
lockSize: ratio
baseColor: #81d657
Shape {
Circle { x: 10; y: 10; radius: 7 }
}
}
Icon {
id: Activity
elements: item
stereotype: 'activity'
display: icon
width: 40
height: 20
baseColor: #81d657
Shape {
RoundedRect { x: 0; y: 0; width: 40; height: 20; radius: 10 }
}
}
Icon {
id: Condition
elements: item
stereotype: 'condition'
display: icon
width: 20
height: 20
lockSize: ratio
baseColor: #81d657
Shape {
MoveTo { x: 10; y: 0 }
LineTo { x: 20; y: 10 }
LineTo { x: 10; y: 20 }
LineTo { x: 0; y: 10 }
Close
}
}
Icon {
id: HorizontalBar
Title: "Horizontal Bar"
elements: item
stereotype: 'horizontalbar'
display: icon
width: 20
height: 5
minWidth: 20
minHeight: 5
lockSize: height
baseColor: #000000
Shape {
RoundedRect { x: 0; y: 0; width: 20; height: 5; radius: 1 }
}
}
Icon {
id: VerticalBar
Title: "Vertical Bar"
elements: item
stereotype: 'verticalbar'
display: icon
width: 5
height: 20
minWidth: 5
minHeight: 20
lockSize: width
baseColor: #000000
Shape {
RoundedRect { x: 0; y: 0; width: 5; height: 20; radius: 1 }
}
}
Icon {
id: Termination
elements: item
stereotype: 'termination'
display: icon
width: 20
height: 20
lockSize: ratio
baseColor: #81d657
Shape {
Circle { x: 10; y: 10; radius: 10 }
Circle { x: 10; y: 10; radius: 7 }
}
}
// **************
// ** Toolbars **
// **************
Toolbar {
id: Classes
Tools {
Tool { title: "Package"; element: package }
Tool { title: "Class"; element: class }
Tool { title: "Interface"; element: class; stereotype: "interface" }
Tool { title: "Control"; element: class; stereotype: "control" }
Tool { title: "Entity"; element: class; stereotype: "entity" }
Tool { title: "Boundary"; element: class; stereotype: "boundary" }
Separator
Tool { title: "Annotation"; element: annotation }
Tool { title: "Boundary"; element: boundary }
}
}
Toolbar {
id: Components
Tools {
Tool { title: "Package"; element: package }
Tool { title: "Component"; element: component }
Tool { title: "Database"; element: component; stereotype: "database" }
Separator
Tool { title: "Annotation"; element: annotation }
Tool { title: "Boundary"; element: boundary }
}
}
Toolbar {
id: UseCases
Tools {
Tool { title: "Package"; element: package }
Tool { title: "UseCase"; element: item; stereotype: "usecase" }
Tool { title: "Actor"; element: item; stereotype: "actor" }
Separator
Tool { title: "Annotation"; element: annotation }
Tool { title: "Boundary"; element: boundary }
}
}
Toolbar {
id: Activities
Tools {
Tool { title: "Start"; element: item; stereotype: "start" }
Tool { title: "Activity"; element: item; stereotype: "activity" }
Tool { title: "Condition"; element: item; stereotype: "condition" }
Tool { title: "Horiz. Bar"; element: item; stereotype: "horizontalbar" }
Tool { title: "Vert. Bar"; element: item; stereotype: "verticalbar" }
Tool { title: "Termination"; element: item; stereotype: "termination" }
Separator
Tool { title: "Annotation"; element: annotation }
Tool { title: "Boundary"; element: boundary }
}
}