(クラス)
public GraphicShape
{inherits
Shape}
Shape 階層への Graphic の埋め込みを可能にする Shape の実装。
説明
GraphicShape を使用すると、Graphic を Shape の子として追加できます。すべての Shape の子と同様に、ローカル変換はその親を基準にします。ただし、Graphic は回転またはスケール変更できないので、回転またはスケーリングが変換に含まれていても無視されます。(この技術は「ビルボード」と呼ばれることもあります。)
プログラミング注意事項
GraphicShape は、そのコンストラクタを使用して明示的に作成できます。別の方法として、Graphic は Shape を必要とするメソッドに渡されると、暗黙的に GraphicShape にキャストされます。
注意事項
Graphicは、
GraphicShapeを要求しなくとも、
Canvasの通常の子でもありうることに留意してください。
GraphicShapeを使用する唯一の理由は、通常、変形またはオプションの継承の為に、シェイプの階層そのものの中に、
Graphicを表示することだけです。
このオブジェクトは、"GraphicShape"のスタイル ルールを記述することによってスタイル化することが出来ます。
例
次の例では、GraphicShape に対する親の変換の結果を表示するアニメーション シーンを示しています。四角形が親で GraphicShape が子です。
例 |
|
{import * from CURL.GUI.SHAPES}
{let parent:RectangleShape =
{RectangleShape
{GRect .5cm, .5cm, .5cm, .5cm},
translation = {Distance2d 2.5cm, 2.5cm}
}
}
{value
{parent.add
{CommandButton
horigin = "left",
label = "Try to hit me!",
{on Action do
{if parent.color == FillPattern.black then
set parent.color = FillPattern.gray
else
set parent.color = FillPattern.black
}
}
}
}
let start:DateTime = {DateTime}
let tmr:Timer =
{parent.animate
frequency=30fps, || 30 frames per second
repeat = 0,
{on TimerEvent do
let elapsed:Time = {start.elapsed}
{parent.set-translation-in-parent 2.5cm + 1cm * {sin elapsed * (30deg / 1s)}, 2.5cm}
{parent.set-rotation elapsed * (20deg / 1s)}
}
}
let run-button:CommandButton =
{CommandButton label = "Start",
{on Action do
set start = {DateTime}
set tmr.repeat = 500
}
}
let stop-button:CommandButton =
{CommandButton label = "Stop",
{on Action do
set tmr.repeat = 0
}
}
{HBox
spacing = .125cm,
run-button,
stop-button
}
}
{Canvas
width = 10cm,
height = 10cm,
parent
}
| |
コンストラクタ protected | {GraphicShape.clone-appearance-from} |
コンストラクタ public | {GraphicShape.default ...} |
アクセサ protected GraphicShape.clonable-class?:
bool
graphic: | この ShapeGraphic 内に含まれるグラフィックです。 |
アクセサ public final GraphicShape.graphic:#
Graphic セッター public final GraphicShape.graphic:#
Graphic
非ローカル オプション public GraphicShape.shape-root:#
ShapeRoot
アクセサ public GraphicShape.style-element:
String プロパティ 継承 Shape:
as-Shape, border-color, color, draw-operation, graphical-parent, option-parent, possibly-displayed?, selection-context, shape-parent, shape-selectable, stroke-thickness, transformation, visible? プロパティ 継承 Visual:
_style-element, completely-clonable-children?, cursor, data-source, display-context, dragee, font-size, has-key-focus?, input-method-enabled?, input-method-keyboard-mode, name, options, style-class, style-manager, style-options, test-child?, test-description, test-name, test-parent?, test-type-name, test-visible?, tooltip, user-data, visual-parent
protected | {GraphicShape.clone-appearance-helper}:Visual |
draw: | このオブジェクトの可視表現を描画します。 |
public | {GraphicShape.fire-crossing-event}:void |
public | {GraphicShape.get-own-bounds dest:GRect = {GRect.empty}}:GRect |
public | {GraphicShape.get-own-bounds-in-shape-root dest:GRect = {GRect.empty} }:GRect |
public | {GraphicShape.get-own-layout-bounds}:GRect |
public | {GraphicShape.non-keyword-init-arg a:any}:void |
public | {GraphicShape.note-graphic-detaching}:void |
public | {GraphicShape.notify-option-children}:void |
public | {GraphicShape.register-options}:void |
public | {GraphicShape.request-draw}:void |
public | {GraphicShape.request-draw-self}:void |
public | {GraphicShape.self-intersects-polygon?}:bool |
public | {GraphicShape.transformation-changed}:void |
public | {GraphicShape.transformation-changing}:void |
メソッド 継承 Shape:
apply-rotation, apply-scale, apply-transformation, apply-translation, apply-translation-in-parent, constrain-own-layout-bounds, constrain-shape-layout-bounds, contains-point?, detach, find-graphical-ancestor, fire-in-child, get-display-context, get-down-orientation-in-shape-parent, get-graphical-root, get-gui-path, get-gui-path-to-child, get-local-device-pixel-size, get-origin-in-graphical-ancestor, get-origin-in-root, get-origin-in-shape-parent, get-origin-in-shape-root, get-right-orientation-in-shape-parent, get-shape-bounds, get-shape-bounds-in-shape-root, get-shape-layout-bounds, get-top-left-in-ancestor, get-transformation-to-shape-root, keyword-init-arg, option-change-notify, overdraw-for-selection, quantize-line-thickness, reset-transformation, set-rotation, set-scale, set-transformation, set-translation-in-parent, to-Graphic, transform-from-display-coordinates, transform-from-graphical-root-coordinates, transform-point-from-shape-root, transform-point-to-shape-root, transform-to-display-coordinates, transform-to-graphical-root-coordinates, transform-vector-from-shape-root, transform-vector-to-shape-root メソッド 継承 ShapeContainerBase:
add, clear, clone-children, draw-shape-child, draw-shape-children, get-all-children-at-point, get-child-at-point, get-leaf-at-point, get-shape-root, note-attached, note-detaching, on-drag-enter, on-pointer-enter, on-pointer-envelope-event, remove, set-shape-index, set-shape-index-after, set-shape-index-before, shape-container-fire-inferior-crossing-event, shape-container-handle-crossing, shape-container-pick-child, shape-container-pointer-enter-occurred, shape-container-pointer-leave-occurred メソッド 継承 Visual:
add-from-init-args, animate, change-cursor, clonable-appearance?, clone-appearance, find-test-children, get-focus-manager, get-layout-context, get-test-parent, get-test-property, get-text, get-view, maybe-fire-attach-event, maybe-fire-detach-event, note-caret-position, on-drag-leave, on-pointer-leave, pop-cursor, prepare-test-object, prepare-test-parent, push-cursor, quantize-width, refresh-style-options, release-key-focus, request-key-focus, scroll-to-include, test-record, test-run, xy-offset-to メソッド 継承 GuiEventTarget:
handle-delegate-event, handle-event, on-action, on-cancel-mode, on-command-changed, on-commit, on-composition-change-event, on-composition-result-event, on-context-menu-event, on-current-record-change-request, on-current-record-changed, on-destroy-notify, on-destroy-requested, on-drag-over, on-drag-pointer, on-drag-started, on-drop, on-end-composition-event, on-focus-event, on-focus-in, on-focus-out, on-gesture, on-gesture-begin, on-gesture-end, on-gesture-magnify, on-gesture-pan, on-gesture-rotate, on-gesture-swipe, on-gesture-tap, on-gesture-touch, on-grab-release, on-gui-event, on-input-method-event, on-inspection, on-key-event, on-key-press, on-pointer-button, on-pointer-crossing, on-pointer-event, on-pointer-motion, on-pointer-press, on-pointer-release, on-pointer-scroll, on-raw-key-event, on-raw-key-press, on-raw-key-release, on-reset, on-selectable-added, on-selectable-removed, on-selection-changed, on-selection-context-activated, on-selection-context-deactivated, on-selection-event, on-start-composition-event, on-start-event, on-stop-event, on-view-activate, on-view-deactivate, on-window-close, remove-event-handlers-for-event-class メソッド 継承 OptionListInterface:
add-option, add-style-option, change-option-parent-notify, clone-options, get-option, get-option-by-name, local-add-notify, local-remove-notify, name-to-option-key, new-option-item, option-changed, option-lookup, option-lookup-here, option-propagate-notify, option-set?, propagate-option-change, remove-option, remove-style-option, remove-styles, set-option-by-name, set-style-option-by-name, unset-option-by-name, unset-style-option-by-name
(コンストラクタ)
protected | {GraphicShape.clone-appearance-from} |
新規オブジェクトを生成するためのコンストラクタ。
fixup:
このプロシージャは二つの引数と共に呼び出されます。元のオブジェクトと clone-appearance のメカニズムによって生成されたコピーオブジェクトです。このプロシージャによって返された値はクローンとして使用されます。このプロシージャはコピーするオブジェクトに修正を加えて返すことができます。このプロシージャが null を返すことはできません。
説明
クローン化をサポートする
GraphicShape のサブクラスはこのコンストラクタを呼び出すコンストラクタを持たなければなりません。クローンされた子に追加しなければならない情報があるかどうか分からない場合、このコンストラクタはサブクラスの子のクローンを作成しません。このクラスのサブクラスは子のクローンを作成しそれらを追加する必要があります。追加の情報が必要でない場合、単に
GraphicShape.clone-children を呼び出すだけです。そうでない場合は、
GraphicShape.clone-children をオーバーライドしそれを呼び出さなければなりません。通常、clone-apperance-from コンストラクタから呼び出される
GraphicShape.clone-children は以下のようになります。
{if {type-of self} == {compile-time-type-of self} then
{self.clone-children other, fixup}
}
(コンストラクタ)
public | {GraphicShape.default ...} |
新しい GraphicShape を作成します。
説明
(アクセサ)
アクセサ protected GraphicShape.clonable-class?:
bool 当該クラスがクローン化可能である場合は、true を返します。その他の場合は false を返します。
オーバーライド
既定の実装は
false を返します。クローン化機能を提供するクラスは、
{type-of self} == {compile-time-type-of self} を返すためには、このゲッターをオーバーライドする必要があります。クローン化可能な
Visual が必ずしもクローン化可能であるとは限らないので、単に
true を返すだけでは正しくありません。
(アクセサ)
アクセサ public final GraphicShape.graphic:#
Graphic セッター public final GraphicShape.graphic:#
Graphic この ShapeGraphic 内に含まれるグラフィックです。
説明
このセッターを使用して、グラフィックを追加、削除、または置換できます。
(非ローカル オプション)
Shape 階層の現在の形状ルート (オプション形式)。
説明
(アクセサ)
アクセサ public GraphicShape.style-element:
String スタイリングの目的のための、この Visual の "要素" や "型" です。
説明
オーバーライド
Visual のサブクラスのスタイルが他のオブジェクトと異なる場合、このゲッターは適切な文字列を返すようにオーバーライドされる必要があります。 慣例では,この文字列はクラス名または、オブジェクトを生成するマークアップの名前です。
オーバーライドでは、空の文字列でないかぎり、self._style-elementを返さなければなりません。
導入:
バージョン 6.0
(メソッド)
protected | {GraphicShape.clone-appearance-helper}:Visual |
クローンを作成し、クローン自体を返します。
オーバーライド
既定の実装はエラーをスローします。クローン化機能を提供するクラスは、
{{compile-time-type-of self}.clone-appearance-from self, fixup}
を返すためには、このゲッターをオーバーライドする必要があります。
(メソッド)
このオブジェクトの可視表現を描画します。
オーバーライド
Shape をサブクラス化する場合は、このメソッドをオーバーライドする必要があります。
(メソッド)
public | {GraphicShape.fire-crossing-event}:void |
(メソッド)
public | {GraphicShape.get-own-bounds dest:GRect = {GRect.empty}}:GRect |
ローカル座標系におけるこの Shape の四角形のレンダリング境界を計算します。
dest: データを返すために使用されるオプションの GRect オブジェクト。
戻り値
境界を含む
GRect オブジェクト。これは、常に
dest と同じオブジェクトになります。この
GRect は正しい形式である必要があります。つまり、次の条件が true でなければなりません。
-dest.lextent <= dest.rextent and -dest.ascent <= dest.descent
説明
返された境界は、このオブジェクトによって描画されるすべてのピクセルをカバーしている必要があります。ただし、このオブジェクトのすべての子を含んでいません。
注意事項
オーバーライド
Shape をサブクラス化する場合は、このメソッドをオーバーライドする必要があります。データを返すには、dest パラメータを使用する必要があります。
(メソッド)
public | {GraphicShape.get-own-bounds-in-shape-root dest:GRect = {GRect.empty} }:GRect |
形状ルートである祖先の座標系における、この形状の四角形のレンダリング境界を計算します。
dest: データを返すために使用されるオプションの GRect オブジェクト。
戻り値
境界を含む
GRect オブジェクト。これは、常に
dest と同じオブジェクトになります。この
GRect は正しい形式である必要があります。つまり、次の条件が true でなければなりません。
-dest.lextent <= dest.rextent and -dest.ascent <= dest.descent
説明
返された境界は、このオブジェクトによって描画されるすべてのピクセルをカバーしている必要があります。ただし、このオブジェクトのすべての子を含んでいません。
注意事項
形状ルートを持たない形状に対してこのメソッドを呼び出すことはできません。例外が発生します。
オーバーライド
軸平行の四角形を使用するよりも厳密な方法でオブジェクトの境界を変換できる場合は、このメソッドを独自の Shape 実装でオーバーライドすることをお勧めします。
(メソッド)
public | {GraphicShape.get-own-layout-bounds}:GRect |
ローカル座標系におけるこの Shape の四角形のレイアウト境界を計算します。
width-first?:
GraphicShape の場合、width-first レイアウト ネゴシエーションを使用して計算されるべき境界であるかを示します。このパラメータは、通常他のサブクラスでは使用されません。
dest: データを返すために使用されるオプションの GRect オブジェクト。
戻り値
境界を含む
GRect オブジェクト。これは、常に
dest と同じオブジェクトになります。この
GRect は正しい形式である必要があります。つまり、次の条件が true でなければなりません。
-dest.lextent <= dest.rextent and -dest.ascent <= dest.descent
説明
返された境界には、レイアウトの使用について、オブジェクトに関する詳細な記述があります。ただし、このオブジェクトのすべての子は含まれていません。
注意事項
オーバーライド
(メソッド)
public | {GraphicShape.non-keyword-init-arg a:any}:void |
InitRestArgParser.process-rest-args で非キーワード引数が検出されると、呼び出されます。
説明
Visual によるこのメソッドの実装では、最初にこのメソッドへの入力値をオブジェクトに関連するメタデータとして解釈を試みます。たとえば、オブジェクトに関連する
EventHandler と
DataBinding を認識してから、これらをアタッチするための適切な手順を実行することになります。
オーバーライド
オブジェクトに関連付けられた追加のメタデータも受け入れるようにするには、このメソッドをオーバーライドします。実装では通常、解釈に失敗した入力値でスーパー実装が呼び出されるようにします。
(メソッド)
public | {GraphicShape.note-graphic-detaching}:void |
GraphicShape に、その Graphic が階層から切り離されることを通知する場合に呼び出されます。
説明
(メソッド)
public | {GraphicShape.notify-option-children}:void |
このオブジェクトのオプションの子にオプションが変更されたことを通知します。
item: 追加または削除されたバインディング オプション。
removed?: item が削除された場合は true、それ以外の場合は false。
オーバーライド
(メソッド)
public | {GraphicShape.register-options}:void |
このオブジェクトがバインドのモニタリングを必要とする非ローカル オプション キーを登録します。
プログラミング注意事項
このメソッドは、オブジェクトがモニタしているオプション キーを確認する必要がある場合に任意のコード内で呼び出されます。このメソッドは、プロシージャ
p をまったく呼び出さないかまたは何回か呼び出し、呼び出すたびに引数として
OptionKey を渡す必要があります。このオブジェクトによりモニタリングされるオプション キーのセットは、
p のすべての呼び出しで指定されたオプション キー セットの連結であると見なされます。
p を複数回呼び出せるという能力を利用して、オプション親はモニタの対象となるオプション キーのリストを指定して
p を一度呼び出し、次に、同じ引数
p を与えてオプションの子それぞれの
register-options メソッドを呼び出し、このメソッドの目的を果たすことができます。この方法はシンプルですが、ほとんどの場合は、オプション親がその子における
register-options 呼び出しの結果をキャッシュして、親の
register-options メソッドが呼び出されたときにそのリストを提供する方がより効率的です。ローカル バインディング オプションへの変更通知は、それらのキーが登録されていない場合でも行われます。
オーバーライド
OptionListInterface.register-options の既定の実装は、このオブジェクトの変更ハンドラを持つ各非ローカル オプションで
p を呼び出します。サブクラスは、
{super.register-options p} を呼び出し、登録される必要がある追加のオプション キー上全てで、
p を呼び出すように、このメソッドをオーバーライドする必要する必要があります。一般的に、これらの追加のオプション キーは、子供または子孫のオブジェクトが監視する必要がある非ローカル オプションに対応します。それは、このオブジェクトの子オブジェクト上で、
register-options を呼び出すことによって決定されます。
注意 一般的に、このメソッドをオーバーライドする必要があるオブジェクトだけが、オプションの子を持つオブジェクトです。
(メソッド)
public | {GraphicShape.request-draw}:void |
描画する Visual に属するピクセルを確認します。
注意事項
プログラミング注意事項
このオブジェクトのピクセルの再ペイントが必要になる何らかの理由があったとき、このメソッドが呼び出されます。このような状況が発生するのは、オブジェクトが初めて表示されるとき、ビューから削除されるとき、移動やサイズ変更が行なわれるとき (この場合、移動やサイズ変更の前と後でこのメソッドを呼び出す必要があります) などがあります。
(メソッド)
public | {GraphicShape.request-draw-self}:void |
再描画する Shape に属するピクセルを要求します。
説明
(メソッド)
ポイントがこの Shape 内にあるかどうかを判定します。
x: 点の X 座標。
y: 点の Y 座標。
戻り値
この Shape が (x、y) を含む場合は、true。
説明
ポイントは、このオブジェクトのローカル座標系にあります。このメソッドはその子を考慮しません。
(メソッド)
public | {GraphicShape.self-intersects-polygon?}:bool |
ポリゴンがこの Shape と交差するかどうかを判定します。
polygon: この形状のローカル座標空間にポリゴンを記述するポイント セットを含むオブジェクト。このポリゴンは必ず凸型であり、反時計回りのワインディング順に従います。
説明
オーバーライド
Shape をサブクラス化する場合は、このメソッドをオーバーライドする必要があります。子を考慮する必要はありません。
通常は、このメソッドを実装して、領域が形状の境界内にあるかどうかだけでなく、領域が形状のレンダリングされたプリミティブと交差するかどうかを確認する必要があります。このメソッドは、必要なメトリックを使用して自在に実装できます。このメソッドの実装が
Shape.self-contains-point? と調和しない場合は、このオブジェクトを選択すると予期しない結果になります。
選択機能を使用しない場合は、このメソッドを単純に false を返すように実装できます。
(メソッド)
public | {GraphicShape.transformation-changed}:void |
Shape.transformation が変更されたことの通知。
オーバーライド
重要:このメソッドのオーバーライド実装にスーパークラス実装の呼び出しを含めて、オブジェクトの新しい領域を無効にする必要があります。
(メソッド)
public | {GraphicShape.transformation-changing}:void |
Shape.transformation が変更されることの通知。
オーバーライド
重要:このメソッドのオーバーライド実装にスーパークラス実装の呼び出しを含めて、オブジェクトの現在の領域を無効にし、変換変更の通知が Shape 階層全体に適切に送信されるようにする必要があります。