ImageShape (クラス)
public ImageShape {inherits Shape}
パッケージ: CURL.GUI.SHAPES

Pixmap を表示する Shape の実装。

説明

イメージの表示方法は、例示した方法でこのオブジェクトに対して利用できるセッターで制御できます。さらに、ImageShapeShape.transformation フィールドを使用して、その位置、回転、およびスケールを他の形状と同じ方法で決定します。オプションで変換に含まれる回転またはスケールを無視して、「ビルボード」イメージとして参照されるものを提示することもあります。これは既定であり、ImageShape.fixed-transformation? によって制御されます。
拡大縮小しない、もしくはタイル処理をしないと仮定すると、イメージのピクセルは Renderer2d.pixel-size によって定義されるように論理的なスクリーンにマップされます。これは高解像度のディスプレイでは、 1 : 1 の比率とはなりません。また、画像が印刷される時には、他の Shapeに関連する画像のサイズが保護されるように、(Distance 単位で測定された) 同じサイズが使用されます。

注意事項

通常、回転されたイメージは表示されません。Canvas.use-host-rendering?をfalseに設定することで、この機能(及び他の機能も)をサポートするように出来ます。ただし、この結果パフォーマンスが悪くなることに留意してください。このクラスは以下のオプションを使用します。:
このオブジェクトは、"ImageShape"のスタイル ルールを記述することでスタイル化することが出来ます。

次の例では、fixed-transformation? を除く ImageShape のすべてのパラメータを示しています。GraphicShapeImageShape と同じアルゴリズムを固定変換に使用します。このアルゴリズムの効果を示す例については、GraphicShape の説明を参照してください。

{import * from CURL.GUI.SHAPES}
{import * from CURL.GRAPHICS.IMAGEFILTER}

{let shape:ImageShape =
    {ImageShape
        translation = {Distance2d 4cm, 4cm},
        {filter-pixmap
            scale,
            {Pixmap.from-url
                {url "curl://install/docs/default/images/adria.jpg"}
            },
            scale = 50%
        }
    }
}

{VBox
    spacing = .125cm,
    halign = "center",
    border-width = 1px,
    "tiles (x, y):",
    {HBox
        {TextField
            width = .5in,
            value = {format "%.2f", shape.tiles.x},
            {on ValueFinished at tf:TextField do
                set shape.tiles =
                    {Double2d {tf.value.to-double}, shape.tiles.y}
            }
        },
        {TextField
            width = .5in,
            value = {format "%.2f", shape.tiles.y},
            {on ValueFinished at tf:TextField do
                set shape.tiles =
                    {Double2d shape.tiles.x, {tf.value.to-double}}
            }
        }
    }
}
{VBox
    spacing = .125cm,
    halign = "center",
    border-width = 1px,
    "pixmap-scale (x, y):",
    {HBox
        {TextField
            width = .5in,
            value = {format "%.2f", shape.pixmap-scale.x},
            {on ValueFinished at tf:TextField do
                set shape.pixmap-scale =
                    {Double2d {tf.value.to-double}, shape.pixmap-scale.y}
            }
        },
        {TextField
            width = .5in,
            value = {format "%.2f", shape.pixmap-scale.y},
            {on ValueFinished at tf:TextField do
                set shape.pixmap-scale =
                    {Double2d shape.pixmap-scale.x, {tf.value.to-double}}
            }
        }
    }
}
{VBox
    spacing = .125cm,
    halign = "center",
    border-width = 1px,
    "pixmap-offset (x, y):",
    {HBox
        {TextField
            width = .5in,
            value = {format "%.2f", shape.pixmap-offset.x},
            {on ValueFinished at tf:TextField do
                set shape.pixmap-offset =
                    {Double2d {tf.value.to-double}, shape.pixmap-offset.y}
            }
        },
        {TextField
            width = .5in,
            value = {format "%.2f", shape.pixmap-offset.y},
            {on ValueFinished at tf:TextField do
                set shape.pixmap-offset =
                    {Double2d shape.pixmap-offset.x, {tf.value.to-double}}
            }
        }
    }
}
{HBox
    spacing = .125cm,
    border-width = 1px,
    {VBox
        spacing = .125cm,
        halign = "center",
        "halign: ",
        {TextField
            width = .5in,
            value = shape.halign,
            tooltip =
                {Tooltip
                    {text
                        Valid alignments are
                        {monospace left}, {monospace
                        center}, {monospace origin},
                        {monospace right}, or a number
                        in the range of 0.0 to 1.0.
                    }
                },
            {on ValueFinished at field:TextField do
                let (val:double, chars:int) = {field.value.to-double}
                {if chars == field.value.size then
                    set shape.halign = val
                 else
                    set shape.halign = field.value
                }
            }
        }
    },
    {VBox
        spacing = .125cm,
        halign = "center",
        "valign: ",
        {TextField
            width = .5in,
            value = shape.valign,
            tooltip =
                {Tooltip
                    {text
                        Valid alignments are
                        {monospace top}, {monospace
                        center}, {monospace origin},
                        {monospace bottom}, or a number
                        in the range of 0.0 to 1.0.
                    }
                },
            {on ValueFinished at field:TextField do
                let (val:double, chars:int) = {field.value.to-double}
                {if chars == field.value.size then
                    set shape.valign = val
                 else
                    set shape.valign = field.value
                }
            }
        }
    }
}

{Canvas
    width = 8cm,
    height = 8cm,
    border-width = 1px,
    shape
}

コンストラクタ
clone-appearance-from:新規オブジェクトを生成するためのコンストラクタ。
コンストラクタ protected {ImageShape.clone-appearance-from
other:ImageShape,
fixup:#{proc-type {Visual, Visual}:Visual}
}
default:新しい ImageShape を作成します。
コンストラクタ public {ImageShape.default image:Pixmap, ...}

プロパティ
clonable-class?:当該クラスがクローン化可能である場合は、true を返します。その他の場合は false を返します。
アクセサ protected ImageShape.clonable-class?:bool
fixed-transformation?:回転とスケールを固定してイメージを表示するかどうかを示すフラグ。
アクセサ public final ImageShape.fixed-transformation?:bool
セッター public final ImageShape.fixed-transformation?:bool
halign:このオブジェクトの起点に対する水平方向のイメージ配置です。
ローカル オプション public ImageShape.halign:any ="origin"
image:この ImageShape 内に表示されるイメージです。
アクセサ public final ImageShape.image:Pixmap
セッター public final ImageShape.image:Pixmap
pixmap-offset:イメージに適用されるオフセットです。
アクセサ public final ImageShape.pixmap-offset:Double2d
セッター public final ImageShape.pixmap-offset:Double2d
pixmap-scale:イメージに適用されるスケールです。
アクセサ public final ImageShape.pixmap-scale:Double2d
セッター public final ImageShape.pixmap-scale:Double2d
style-element:スタイリングの目的のための、この Visual の "要素" や "型" です。
アクセサ public ImageShape.style-element:String
tiles:表示されるイメージのタイル数、つまり繰り返し回数です。
アクセサ public final ImageShape.tiles:Double2d
セッター public final ImageShape.tiles:Double2d
valign:このオブジェクトの起点に対する垂直方向のイメージ配置です。
ローカル オプション public ImageShape.valign:any ="origin"
プロパティ 継承 Shape: as-Shape, border-color, color, draw-operation, graphical-parent, option-parent, possibly-displayed?, selection-context, shape-parent, shape-selectable, stroke-thickness, transformation, visible?
プロパティ 継承 ShapeContainerBase: as-ShapeRoot, shape-children
プロパティ 継承 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
プロパティ 継承 DataBindingTarget: data-binding-context, data-bindings
プロパティ 継承 EventTarget: event-handlers
プロパティ 継承 OptionListInterface: option-register-proc, options-present-here, registered-option-keys

メソッド
clone-appearance-helper:クローンを作成し、クローン自体を返します。
protected {ImageShape.clone-appearance-helper
fixup:#{proc-type {Visual, Visual}:Visual}
}:Visual
draw:このオブジェクトの可視表現を描画します。
public {ImageShape.draw renderer2d:Renderer2d}:void
get-own-bounds:ローカル座標系におけるこの Shape の四角形のレンダリング境界を計算します。
public {ImageShape.get-own-bounds dest:GRect = {GRect.empty}}:GRect
get-own-bounds-in-shape-root:形状ルートである祖先の座標系における、この形状の四角形のレンダリング境界を計算します。
public {ImageShape.get-own-bounds-in-shape-root
dest:GRect = {GRect.empty}
}:GRect
keyword-init-arg: InitRestArgParser.process-rest-args でキーワード引数が検出されると呼び出されます。
protected {ImageShape.keyword-init-arg key:String, value:any}:void
overdraw-for-selection:このオブジェクトの上に選択アフォーダンスを描画します。
public {ImageShape.overdraw-for-selection}:void
self-contains-point?:ポイントがこの Shape 内にあるかどうかを判定します。
public {ImageShape.self-contains-point? x:Distance, y:Distance}:bool
self-intersects-polygon?:ポリゴンがこの Shape と交差するかどうかを判定します。
public {ImageShape.self-intersects-polygon?}:bool
メソッド 継承 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-crossing-event, 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-own-layout-bounds, 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, option-change-notify, quantize-line-thickness, request-draw, request-draw-self, 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, transformation-changed, transformation-changing
メソッド 継承 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, notify-option-children, on-drag-enter, on-pointer-enter, on-pointer-envelope-event, register-options, 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, non-keyword-init-arg, 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
メソッド 継承 GraphicOptions: any-to-Distance
メソッド 継承 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
メソッド 継承 DataBindingTarget: add-data-binding, get-data-binding, refresh-data-binding, remove-data-binding, unset-property, update-data-binding, validate-data-binding
メソッド 継承 EventTarget: accepts-event-class?, add-event-handler, event-handler-present?, remove-event-handler, verify-event
メソッド 継承 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
メソッド 継承 BasicEventTarget: enqueue-event
メソッド 継承 InitRestArgParser: process-rest-args
メソッド 継承 Object: object-describe, object-describe-for-debugging, object-serialize



コンストラクタ詳細
clone-appearance-from (コンストラクタ)
protected {ImageShape.clone-appearance-from
other:ImageShape,
fixup:#{proc-type {Visual, Visual}:Visual}
}

新規オブジェクトを生成するためのコンストラクタ。

other: クローンする ImageShape
fixup:
各クローンを作成するために呼び出されるプロシージャ。クローン化する時に使用され ImageShape.clone-children に渡されます。
このプロシージャは二つの引数と共に呼び出されます。元のオブジェクトと clone-appearance のメカニズムによって生成されたコピーオブジェクトです。このプロシージャによって返された値はクローンとして使用されます。このプロシージャはコピーするオブジェクトに修正を加えて返すことができます。このプロシージャが null を返すことはできません。

説明

クローン化をサポートする ImageShape のサブクラスはこのコンストラクタを呼び出すコンストラクタを持たなければなりません。クローンされた子に追加しなければならない情報があるかどうか分からない場合、このコンストラクタはサブクラスの子のクローンを作成しません。このクラスのサブクラスは子のクローンを作成しそれらを追加する必要があります。追加の情報が必要でない場合、単に ImageShape.clone-children を呼び出すだけです。そうでない場合は、ImageShape.clone-children をオーバーライドしそれを呼び出さなければなりません。通常、clone-apperance-from コンストラクタから呼び出される ImageShape.clone-children は以下のようになります。
{if {type-of self} == {compile-time-type-of self} then
    {self.clone-children other, fixup}
}


default (コンストラクタ)
public {ImageShape.default image:Pixmap, ...}

新しい ImageShape を作成します。

image: 表示される Pixmap です。Pixmap は、ほとんどの場合、Pixmap.from-url#factory を使用して作成されます。
...: 通常の Shape の作成引数を渡せます。たとえば、イニシャライザ、変換、子 Shape などです。詳細については、Shape.default を参照してください。



プロパティ詳細
clonable-class? (アクセサ)
アクセサ protected ImageShape.clonable-class?:bool

当該クラスがクローン化可能である場合は、true を返します。その他の場合は false を返します。

オーバーライド

既定の実装は false を返します。クローン化機能を提供するクラスは、{type-of self} == {compile-time-type-of self} を返すためには、このゲッターをオーバーライドする必要があります。クローン化可能な Visual が必ずしもクローン化可能であるとは限らないので、単に true を返すだけでは正しくありません。
このメソッドをオーバーライドする場合は、Visual.clone-appearance-helper もオーバーライドする必要があります。


fixed-transformation? (アクセサ)
アクセサ public final ImageShape.fixed-transformation?:bool
セッター public final ImageShape.fixed-transformation?:bool

回転とスケールを固定してイメージを表示するかどうかを示すフラグ。

説明

このフラグが false の場合、イメージはその変換に含まれる任意のスケールまたは回転で表示されます。回転されたイメージは、通常は表示できません。詳細については、Canvas.use-host-rendering? を参照してください。


halign (ローカル オプション)
public ImageShape.halign:any ="origin"

このオブジェクトの起点に対する水平方向のイメージ配置です。

説明

この値は、文字列または浮動小数点値です。有効な文字列は、「left」、「origin」、「center」、および「right」です。既定値は「origin」であり、「center」と同義です。値が浮動小数点値の場合は、イメージの位置を 0 ~ 1 の範囲で指定します。0 は「left」、1 は「right」と同じ意味です。

注意事項

このパラメータの使用例については、ImageShape のクラスの説明を参照してください。


image (アクセサ)
アクセサ public final ImageShape.image:Pixmap
セッター public final ImageShape.image:Pixmap

この ImageShape 内に表示されるイメージです。

説明

この Pixmap の内容を変更する場合は、新しい内容が表示されるように ImageShape.request-draw を呼び出す必要があります。


pixmap-offset (アクセサ)
アクセサ public final ImageShape.pixmap-offset:Double2d
セッター public final ImageShape.pixmap-offset:Double2d

イメージに適用されるオフセットです。

説明

このパラメータの動作例については、ImageShape のクラスの説明を参照してください。


pixmap-scale (アクセサ)
アクセサ public final ImageShape.pixmap-scale:Double2d
セッター public final ImageShape.pixmap-scale:Double2d

イメージに適用されるスケールです。

説明

このパラメータの動作例については、ImageShape のクラスの説明を参照してください。


style-element (アクセサ)
アクセサ public ImageShape.style-element:String

スタイリングの目的のための、この Visual の "要素" や "型" です。

説明

この実装によって Visual._style-elementの値が返されますが、通常は定数を返すためにオーバーライドされます。

オーバーライド

Visual のサブクラスのスタイルが他のオブジェクトと異なる場合、このゲッターは適切な文字列を返すようにオーバーライドされる必要があります。 慣例では,この文字列はクラス名または、オブジェクトを生成するマークアップの名前です。
オーバーライドでは、空の文字列でないかぎり、self._style-elementを返さなければなりません。
導入: バージョン 6.0


tiles (アクセサ)
アクセサ public final ImageShape.tiles:Double2d
セッター public final ImageShape.tiles:Double2d

表示されるイメージのタイル数、つまり繰り返し回数です。

説明

このパラメータの動作例については、ImageShape のクラスの説明を参照してください。


valign (ローカル オプション)
public ImageShape.valign:any ="origin"

このオブジェクトの起点に対する垂直方向のイメージ配置です。

説明

この値は、文字列または浮動小数点値です。有効な文字列は、「top」、「origin」、「center」、および「bottom」です。既定値は「origin」であり、「center」と同義です。値が浮動小数点値の場合は、イメージの位置を 0 ~ 1 の範囲で指定します。0 は「top」、1 は「bottom」と同じ意味です。

注意事項

このパラメータの使用例については、ImageShape のクラスの説明を参照してください。





メソッド詳細
clone-appearance-helper (メソッド)
protected {ImageShape.clone-appearance-helper
fixup:#{proc-type {Visual, Visual}:Visual}
}:Visual

クローンを作成し、クローン自体を返します。

オーバーライド

既定の実装はエラーをスローします。クローン化機能を提供するクラスは、
{{compile-time-type-of self}.clone-appearance-from self, fixup}
を返すためには、このゲッターをオーバーライドする必要があります。


draw (メソッド)
public {ImageShape.draw renderer2d:Renderer2d}:void

このオブジェクトの可視表現を描画します。

renderer2d: このオブジェクトを使用してそれ自身を描画する Renderer2d

オーバーライド

Shape をサブクラス化する場合は、このメソッドをオーバーライドする必要があります。


get-own-bounds (メソッド)
public {ImageShape.get-own-bounds dest:GRect = {GRect.empty}}:GRect

ローカル座標系におけるこの Shape の四角形のレンダリング境界を計算します。

dest: データを返すために使用されるオプションの GRect オブジェクト。

戻り値

境界を含む GRect オブジェクト。これは、常に dest と同じオブジェクトになります。この GRect は正しい形式である必要があります。つまり、次の条件が true でなければなりません。 -dest.lextent <= dest.rextent and -dest.ascent <= dest.descent

説明

返された境界は、このオブジェクトによって描画されるすべてのピクセルをカバーしている必要があります。ただし、このオブジェクトのすべての子を含んでいません

注意事項

レンダリング境界 (get-own-bounds) とレイアウト境界 (get-own-layout-bounds) は、通常似ていますが、同じではありません。特に、レンダリング境界は非常に包括的ですが、レイアウト境界はそれぞれが整然と隣接するため、Shape を厳密に記述しなければならなりません。

オーバーライド

Shape をサブクラス化する場合は、このメソッドをオーバーライドする必要があります。データを返すには、dest パラメータを使用する必要があります。


get-own-bounds-in-shape-root (メソッド)
public {ImageShape.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.get-own-bounds を呼び出して境界を正しい座標系に変換するために実装されます。

注意事項

形状ルートを持たない形状に対してこのメソッドを呼び出すことはできません。例外が発生します。

オーバーライド

軸平行の四角形を使用するよりも厳密な方法でオブジェクトの境界を変換できる場合は、このメソッドを独自の Shape 実装でオーバーライドすることをお勧めします。


keyword-init-arg (メソッド)
protected {ImageShape.keyword-init-arg key:String, value:any}:void

InitRestArgParser.process-rest-args でキーワード引数が検出されると呼び出されます。

key: キーワード引数でキーとして表示される String
value: キーワード引数で表示される値。

オーバーライド

既定の実装 InitRestArgParser.keyword-init-arg は、呼び出されるとエラーをレポートします。このメソッドは、 InitRestArgParser.process-rest-args に渡される引数リストのキーワード引数を受け入れるサブクラスによってオーバーライドされます。


overdraw-for-selection (メソッド)
public {ImageShape.overdraw-for-selection}:void

このオブジェクトの上に選択アフォーダンスを描画します。

説明

このメソッドは、内部の形状描画メカニズムにより呼び出されます。通常は、直接呼び出す必要はありません。

オーバーライド

このメソッドの既定の実装では、オブジェクトの境界を Shape.get-own-bounds によって返されるものとみなしています。draw-styleinvert の場合は、DrawOperation.invert-destination を使用して四角形をレンダリングします。mask の場合は、Renderer2d.render-stippled-rectangle が使用されます。
Shape の実装でこのメソッドをオーバーライドする必要はありませんが、形状のレンダリングされたプリミティブの真上に選択アフォーダンスを描画したほうが選択が見やすくなる場合があります。


self-contains-point? (メソッド)
public {ImageShape.self-contains-point? x:Distance, y:Distance}:bool

ポイントがこの Shape 内にあるかどうかを判定します。

x: 点の X 座標。
y: 点の Y 座標。

戻り値

この Shape が (xy) を含む場合は、true

説明

ポイントは、このオブジェクトのローカル座標系にあります。このメソッドは、その子を考慮しません。

オーバーライド

Shape をサブクラス化する場合は、このメソッドをオーバーライドする必要があります。このメソッドは、PointerMotion などのマウス イベントをこのオブジェクトにいつ送信するかなどを決定します。
通常は、このメソッドを実装して、ポイントが形状の境界内にあるかどうかだけでなく、ポイントが形状のレンダリングされたプリミティブ内にあるどうかを確認する必要があります。このメソッドは必要なメトリックを使用して自在に実装できます。


self-intersects-polygon? (メソッド)
public {ImageShape.self-intersects-polygon?}:bool

ポリゴンがこの Shape と交差するかどうかを判定します。

polygon: この形状のローカル座標空間にポリゴンを記述するポイント セットを含むオブジェクト。このポリゴンは必ず凸型であり、反時計回りのワインディング順に従います。

説明

このメソッドは、ポイントではなく領域を処理する点を除けば、Shape.self-contains-point? とよく似ています。主に領域ベースの選択をサポートするために使用されますが、直接呼び出すこともできます。

オーバーライド

Shape をサブクラス化する場合は、このメソッドをオーバーライドする必要があります。子を考慮する必要はありません。
通常は、このメソッドを実装して、領域が形状の境界内にあるかどうかだけでなく、領域が形状のレンダリングされたプリミティブと交差するかどうかを確認する必要があります。このメソッドは、必要なメトリックを使用して自在に実装できます。このメソッドの実装が Shape.self-contains-point? と調和しない場合は、このオブジェクトを選択すると予期しない結果になります。
選択機能を使用しない場合は、このメソッドを単純に false を返すように実装できます。