Freezable.CloneCurrentValueCore(Freezable) Freezable.CloneCurrentValueCore(Freezable) Freezable.CloneCurrentValueCore(Freezable) Freezable.CloneCurrentValueCore(Freezable) Method


現在のプロパティ値を使用して、インスタンスを、指定した Freezable の変更可能な複製 (詳細コピー) にします。Makes the instance a modifiable clone (deep copy) of the specified Freezable using current property values.

 virtual void CloneCurrentValueCore(System::Windows::Freezable ^ sourceFreezable);
protected virtual void CloneCurrentValueCore (System.Windows.Freezable sourceFreezable);
abstract member CloneCurrentValueCore : System.Windows.Freezable -> unit
override this.CloneCurrentValueCore : System.Windows.Freezable -> unit
Protected Overridable Sub CloneCurrentValueCore (sourceFreezable As Freezable)


Freezable Freezable Freezable Freezable

複製する FreezableThe Freezable to be cloned.


このメソッドを呼び出して、CloneCurrentValueメソッドが呼び出されないコードから直接を除く中に、このメソッドをオーバーライドする基本実装を呼び出すときにします。This method is called by the CloneCurrentValue method and should not be called directly from your code, except when calling the base implementation while overriding this method. 現在のオブジェクトの変更可能なコピーを作成するにはCloneCurrentValueこのメソッドを直接呼び出す代わりにします。To create a modifiable copy of the current object, call CloneCurrentValue instead of calling this method directly.

注意 (継承者)

派生する場合Freezable、このメソッドをオーバーライドする必要があります。If you derive from Freezable, you may need to override this method. オーバーライドする理由として、次のとおりです。Reasons to override include the following: 派生クラスでは、依存関係プロパティを使用して接続されていないデータがあります。- Your derived class has data that is not exposed via dependency properties.

派生クラスは、単にオーバーライドすることで実現できない追加の初期化作業を実行する必要がありますCreateInstanceCore()します。- Your derived class must perform extra initialization work that cannot be accomplished by simply overriding CreateInstanceCore(). 派生クラスを実装する場合に適用されますこのなどISupportInitializeします。For example, this applies if your derived class implements ISupportInitialize.

依存関係プロパティのすべてのデータを格納して、追加の初期化作業を実行する必要がないクラスは、オーバーライドする必要はありませんCloneCurrentValueCore(Freezable)します。Classes that store all their data in dependency properties and that do not need to perform extra initialization work do not need to override CloneCurrentValueCore(Freezable).

すべての実装が、このメソッドの基本実装を呼び出すことが重要です。It is essential that all implementations call the base implementation of this method. 実装には、既定の実装で実行されていない作業のみを実行する必要があります。Implementations should only perform work that is not performed by the default implementation. 既定の実装では、すべてのローカルに設定、書き込み可能なプロパティの詳細のコピーを作成します。The default implementation makes deep copies of all writable, locally set properties. オブジェクトにデータ バインディングの場合) などの式での依存関係プロパティが含まれている場合は、式自体ではありませんが、式の現在の値がコピーされます。If the object contains dependency properties with expressions (such as a data binding), the current value of the expression is copied but not the expression itself.

オブジェクトが依存関係プロパティをアニメーション化する場合は、これらのプロパティの現在のアニメーション化された値をコピーするが、アニメーションはありません。If the object has animated dependency properties, the current animated value of those properties is copied, but the animations are not.

未設定のプロパティがコピーされないも、プロパティは読み取り専用に注意してください。Note that unset properties are not copied, nor are read-only properties. このようなプロパティが固定されたである既定値を持つかどうかFreezableプロパティの値をそのまま、それ以外の場合に変更可能な複製で固定します。If such a property has a default value that is a frozen Freezable, that property value remains frozen in the otherwise modifiable clone.

次の一覧は、このメソッドの予想される動作をまとめたものです。The following list summarizes the expected behavior for this method.

-生成されたコピーには、すべてのコピーが含まれています。Freezableサブオブジェクト。- The copy produced contains copies of all Freezable sub-objects.

設定を解除し、読み取り専用プロパティはコピーされません。- Unset and read-only properties are not copied.

場合、プロパティをアニメーション化すると、その現在の値をコピーするが animation 自体はありません。- If a property is animated, its current value is copied, but the animation itself is not.

-これらのサブオブジェクトの作成時に固定されます。- None of these sub-objects are frozen on creation.

-コピー自体はフリーズされません。- The copy itself is not frozen.