PropertyAction QML Type

アニメーション中のプロパティの即時変更を指定します。詳細...

Import Statement: import QtQuick
Inherits:

Animation

プロパティ

詳細説明

PropertyActionは、アニメーション中の即時プロパティ変更を指定するために使用されます。プロパティの変更はアニメーションされません。

アニメーション中にアニメーションしないプロパティ値を設定するのに便利です。

たとえば、SequentialAnimation は、イメージのopacity プロパティを.5 に設定し、イメージの幅をアニメーション化した後、opacity1 に戻します:

SequentialAnimation {
    PropertyAction { target: img; property: "opacity"; value: .5 }
    NumberAnimation { target: img; property: "width"; to: 300; duration: 1000 }
    PropertyAction { target: img; property: "opacity"; value: 1 }
}

PropertyActionは、Transition の間にプロパティの変更が発生する正確なポイントを設定するのにも便利です。たとえば、PropertyChangesState で使用され、特定のtransformOrigin を中心にアイテムを回転させる場合、このように実装されるかもしれません:

Item {
    width: 400; height: 400

    Rectangle {
        id: rect
        width: 200; height: 100
        color: "red"

        states: State {
            name: "rotated"
            PropertyChanges { target: rect; rotation: 180; transformOrigin: Item.BottomRight }
        }

        transitions: Transition {
            RotationAnimation { duration: 1000; direction: RotationAnimation.Counterclockwise }
        }

        MouseArea {
            anchors.fill: parent
            onClicked: rect.state = "rotated"
        }
    }
}

しかし、このコードでは、State がトランジション終了時の値を定義するために取られるため、transformOrigin はアニメーションの後まで設定されません。アニメーションはデフォルトのtransformOrigin で回転し、その後Item.BottomRight にジャンプします。これを修正するには、RotationAnimation が始まる前に PropertyAction を挿入します:

transitions: Transition {
    SequentialAnimation {
        PropertyAction { target: rect; property: "transformOrigin" }
        RotationAnimation { duration: 1000; direction: RotationAnimation.Counterclockwise }
    }
}

これにより、transformOrigin プロパティが、Transition の終了状態で定義された値(つまり、PropertyAction オブジェクトで定義された値)に即座に設定され、回転アニメーションが正しいトランスフォーム原点で始まるようになります。

Qt Quickと Qt Qmlのアニメーションとトランジションも参照してください

Property ドキュメント

properties : string

property : string

target : QtObject

targets : list<QtObject> [read-only]

これらのプロパティは、このアクションによって影響を受けるアイテムとそのプロパティを決定します。

これらのプロパティがさまざまな状況でどのように解釈されるかの詳細は、corresponding PropertyAnimation のドキュメントに記載されています。

excludeも参照してください


exclude : list<QtObject> [read-only]

このプロパティは、このアクションの影響を受けるべきではないオブジェクトを保持します。

targets参照して ください。


value : var

このプロパティは、プロパティに設定される値を保持します。

PropertyActionTransition またはBehavior 内で定義されている場合、この値のデフォルトは、Transition の終了状態で定義されている値、またはBehavior のトリガーとなったプロパティ変更の値です。


本ドキュメントに含まれる文書の著作権は、それぞれの所有者に帰属します 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。