PowerTools SPREAD for Windows Forms 10.0J
AddCustomFunction メソッド (ICustomFunctionSupport)


追加する関数
新しいユーザー定義関数を数式で使用するためモデルに追加します。
構文
'Declaration
 
Sub AddCustomFunction( _
   ByVal functionInfo As FunctionInfo _
) 
'使用法
 
Dim instance As ICustomFunctionSupport
Dim functionInfo As FunctionInfo
 
instance.AddCustomFunction(functionInfo)
void AddCustomFunction( 
   FunctionInfo functionInfo
)

パラメータ

functionInfo
追加する関数
次のサンプルコードは、カスタム関数を追加します。
public class CubeFunctionInfo : FarPoint.CalcEngine.FunctionInfo
    {
      public override string Name { get { return "CUBE"; } }
      public override int MinArgs { get { return 1; } }
      public override int MaxArgs { get { return 1; } }
      public override object Evaluate (object[] args)
      {
        double num = FarPoint.CalcEngine.CalcConvert.ToDouble(args[0]);
        return num * num * num;
      }
    }

FarPoint.Win.Spread.Model.ICustomFunctionSupport cfs;
cfs = (FarPoint.Win.Spread.Model.ICustomFunctionSupport)fpSpread1.ActiveSheet.Models.Data;
cfs.AddCustomFunction(new CubeFunctionInfo());
fpSpread1.ActiveSheet.SetFormula(1, 1, "CUBE(4)");
Public Class CubeFunctionInfo
   Inherits FarPoint.CalcEngine.FunctionInfo

   Public Overrides ReadOnly Property Name() As String
        Get
             Return "CUBE"
        End Get
   End Property

   Public Overrides ReadOnly Property MinArgs() As Integer
        Get
             Return 1
        End Get
   End Property

   Public Overrides ReadOnly Property MaxArgs() As Integer
        Get
             Return 1
        End Get
   End Property

   Public Overrides Function Evaluate(ByVal args() As Object) As Object
        Dim num As Double = FarPoint.CalcEngine.CalcConvert.ToDouble(args(0))
        Return num * num * num
   End Function
End Class

Dim cfs As FarPoint.Win.Spread.Model.ICustomFunctionSupport
cfs = FpSpread1.ActiveSheet.Models.Data
cfs.AddCustomFunction(New CubeFunctionInfo())
FpSpread1.ActiveSheet.SetFormula(1, 1, "CUBE(4)")
参照

ICustomFunctionSupport インタフェース
ICustomFunctionSupport メンバ

 

 


© 2004-2017, GrapeCity inc. All rights reserved.