Import Infragistics.Calculations … ’CustomCalculation 関数を使用してカスタム関数を登録します。 Dim absAvg As New CustomCalculationFunction("AbsAvg", Function(x, y) (System.Math.Abs(x) + System.Math.Abs(y)) / 2) calcManager.RegisterUserDefinedFunction(absAvg)
xamCalculationManager コントロールは Microsoft Excel の関数リストと同じように、事前定義されたデフォルト関数セットを提供します。ただし、状況によっては、このセットの拡張や固有のカスタム関数を追加する必要があります。このトピックでは、xamCalculationManager にカスタム関数を追加する方法を紹介します。
以下の表は、以下に提供されたコード例を示しています。
以下のコードは、カスタム関数を作成し、CustomCalculationFunction 関数を使って登録する方法を示します。このクラスは、 CalculationFunction 基本クラスから派生します。関数ロジックを含むデリゲートを供給することによりカスタム関数を作成できます。
Visual Basic の場合:
Import Infragistics.Calculations … ’CustomCalculation 関数を使用してカスタム関数を登録します。 Dim absAvg As New CustomCalculationFunction("AbsAvg", Function(x, y) (System.Math.Abs(x) + System.Math.Abs(y)) / 2) calcManager.RegisterUserDefinedFunction(absAvg)
C# の場合:
using Infragistics.Calculations; … // CustomCalculation 関数を使用してカスタム関数を登録します。 CustomCalculationFunction absAvg = new CustomCalculationFunction("AbsAvg", (x, y) => (System.Math.Abs(x) + System.Math.Abs(y)) / 2); calcManager.RegisterUserDefinedFunction(absAvg);
以下の XAML コードは、カスタム関数 absAvg() の使用方法を説明します。この関数は、数式の中でコード例「カスタム関数の作成」で作成されたものです。
XAML の場合:
<TextBlock x:Name="Value" Width="150" ig:XamCalculationManager.CalculationManager="{Binding ElementName=calcManager}"> <ig:XamCalculationManager.ControlSettings> <ig:ControlCalculationSettings Property="Text" ReferenceId="mulTotal" Formula="absAvg(1, 2)" /> </ig:XamCalculationManager.ControlSettings> </TextBlock>