ConvertEventArgs.Value プロパティ
アセンブリ: System.Windows.Forms (system.windows.forms.dll 内)

ConvertEventArgs の値。

Value プロパティに格納される値は、ConvertEventArgs が返されるイベントによって異なります。ConvertEventArgs は、Format イベントまたは Parse イベントのいずれかで返されます。
ConvertEventArgs が Format イベントで返されると、Value プロパティにはデータ ソースの書式設定されていないプロパティ値が格納されます。Format イベント内で、このプロパティ値を読み込み、その値に書式を設定して、Value プロパティを新しい (書式設定された) 値にリセットします。この操作によって、データ連結コントロールで表示する値が設定されます。
ConvertEventArgs が Parse イベントで返されると、プロパティにはカスタムの書式設定が適用されたデータ バインド コントロールの値が格納されます。Parse イベント内で、この書式設定された値を読み込み、解析して、データ ソースと同じデータ型に変換する必要があります。その後、Value プロパティを書式化されていない値にリセットできます。この操作によってデータ ソースの値が設定されます。データ ソースの型を判断するには、DesiredType プロパティ値を調べます。

Binding を作成し、ConvertEventHandler デリゲートを Parse イベントと Format イベントの両方に追加するコード例を次に示します。さらにこの例では、DataBindings プロパティを使用して、Binding を TextBox コントロールの BindingsCollection に追加します。DecimalToCurrencyString イベント デリゲートは Format イベントに追加され、ToString メソッドを使用して、バインドされた値 (Decimal 型) を通貨として書式設定します。CurrencyStringToDecimal イベント デリゲートは Parse イベントに追加され、コントロールによって表示される値を Decimal 型に変換します。
Private Sub DecimalToCurrencyString(sender As Object, cevent As ConvertEventArgs) ' The method converts only to string type. Test this using the DesiredType. If Not cevent.DesiredType Is GetType(String) Then Return End If ' Use the ToString method to format the value as currency ("c"). cevent.Value = CDec(cevent.Value).ToString("c") End Sub 'DecimalToCurrencyString Private Sub CurrencyStringToDecimal(sender As Object, cevent As ConvertEventArgs) ' The method converts back to decimal type only. If Not cevent.DesiredType Is GetType(Decimal) Then Return End If ' Converts the string back to decimal using the shared Parse method. cevent.Value = Decimal.Parse(cevent.Value.ToString, _ NumberStyles.Currency, nothing) End Sub 'CurrencyStringToDecimal Private Sub BindControl() ' Creates the binding first. The OrderAmount is typed as Decimal. Dim b As New Binding("Text", ds, "customers.custToOrders.OrderAmount") ' Adds the delegates to the events. AddHandler b.Format, AddressOf DecimalToCurrencyString AddHandler b.Parse, AddressOf CurrencyStringToDecimal text1.DataBindings.Add(b) End Sub 'BindControl
private void DecimalToCurrencyString(object sender, ConvertEventArgs cevent) { // The method converts only to string type. Test this using the DesiredType. if(cevent.DesiredType != typeof(string)) return; // Use the ToString method to format the value as currency ("c"). cevent.Value = ((decimal) cevent.Value).ToString("c"); } private void CurrencyStringToDecimal(object sender, ConvertEventArgs cevent) { // The method converts back to decimal type only. if(cevent.DesiredType != typeof(decimal)) return; // Converts the string back to decimal using the static Parse method. cevent.Value = Decimal.Parse(cevent.Value.ToString(), NumberStyles.Currency, null); } private void BindControl() { // Creates the binding first. The OrderAmount is typed as Decimal. Binding b = new Binding ("Text", ds, "customers.custToOrders.OrderAmount"); // Adds the delegates to the events. b.Format += new ConvertEventHandler(DecimalToCurrencyString); b.Parse += new ConvertEventHandler(CurrencyStringToDecimal); text1.DataBindings.Add(b); }
private: void DecimalToCurrencyString( Object^ /*sender*/, ConvertEventArgs^ cevent ) { // The method converts only to string type. Test this using the DesiredType. if ( cevent->DesiredType != String::typeid ) { return; } // Use the ToString method to format the value as currency ("c"). cevent->Value = ( (Decimal^)(cevent->Value) )->ToString( "c" ); } void CurrencyStringToDecimal( Object^ /*sender*/, ConvertEventArgs^ cevent ) { // The method converts back to decimal type only. if ( cevent->DesiredType != Decimal::typeid ) { return; } // Converts the string back to decimal using the static Parse method. cevent->Value = Decimal::Parse( cevent->Value->ToString(), NumberStyles::Currency, nullptr ); } void BindControl() { // Creates the binding first. The OrderAmount is typed as Decimal. Binding^ b = gcnew Binding( "Text",ds,"customers.custToOrders.OrderAmount" ); // Adds the delegates to the events. b->Format += gcnew ConvertEventHandler( this, &Form1::DecimalToCurrencyString ); b->Parse += gcnew ConvertEventHandler( this, &Form1::CurrencyStringToDecimal ); text1->DataBindings->Add( b ); }
private void DecimalToCurrencyString(Object sender, ConvertEventArgs cevent) { // The method converts only to string type. // Test this using the DesiredType. if (!(cevent.get_DesiredType().Equals(String.class.ToType()))) { return ; } // Use the ToString method to format the value as currency ("c"). cevent.set_Value(((System.Decimal)cevent.get_Value()).ToString("c")); } //DecimalToCurrencyString private void CurrencyStringToDecimal(Object sender, ConvertEventArgs cevent) { // The method converts back to decimal type only. if (!(cevent.get_DesiredType().Equals(System.Decimal.class.ToType()))) { return ; } // Converts the string back to decimal using the static Parse method. cevent.set_Value(Decimal.Parse(cevent.get_Value().ToString(), NumberStyles.Currency, null)); } //CurrencyStringToDecimal private void BindControl() { // Creates the binding first. The OrderAmount is typed as Decimal. Binding b = new Binding("Text", ds, "customers.custToOrders.OrderAmount"); // Adds the delegates to the events. b.add_Format(new ConvertEventHandler(DecimalToCurrencyString)); b.add_Parse(new ConvertEventHandler(CurrencyStringToDecimal)); text1.get_DataBindings().Add(b); } //BindControl

Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


- ConvertEventArgs.Value プロパティのページへのリンク