AxHost.InvalidActiveXStateException クラス

無効な状態にある ActiveX コントロールを参照したときにスローされる例外。

この型のすべてのメンバの一覧については、AxHost.InvalidActiveXStateException メンバ を参照してください。

System.Object
   System.Exception
      System.Windows.Forms.AxHost.InvalidActiveXStateException

Public Class AxHost.InvalidActiveXStateException
   Inherits Exception
[C#]
public class AxHost.InvalidActiveXStateException : Exception
[C++]
public __gc class AxHost.InvalidActiveXStateException : public
   Exception
[JScript]
public class AxHost.InvalidActiveXStateException extends Exception

スレッドセーフ

この型の public static (Visual Basicでは Shared) のすべてのメンバは、マルチスレッド操作で安全に使用できます。インスタンスのメンバの場合は、スレッドセーフであるとは限りません。

解説

ActiveX コントロールのパブリック プロパティおよびパブリック メソッドは、ActiveX コントロールが完全にインスタンス化および初期化された後でなければ参照できません。これらの処理が完了していない場合は、 AxHost.InvalidActiveXStateException 例外がスローされます。 AxHost.InvalidActiveXStateException 例外クラスには、参照を行ったメンバの名前とメンバの型が含まれます。メンバの型は、 AxHost.ActiveXInvokeKind 列挙値の 1 つです。

使用例

[C#] Microsoft Masked Edit ActiveX コントロールをラップする AxHost の派生クラスのコンストラクタ、 SetAboutBoxDelegate メソッド、および AttachInterfaces メソッドをオーバーライドする例を次に示します。このコードは、MSMask32.ocx ファイル上で /source スイッチを使用して AxImp.exe を実行し、編集対象となるラッパー クラスを生成することで、生成されるソース コードを作成済みであることを前提としています。AxImp.exe の出力言語は C# だけなので、ここでは C# 構文のコードだけを示します。

 
public AxMaskEdBox() : 
  base("c932ba85-4374-101b-a56c-00aa003668dc") // The ActiveX control's class identifier.
{
   // Make the AboutBox method the about box delegate.
   this.SetAboutBoxDelegate(new AboutBoxDelegate(AboutBox));
}
        
public virtual void AboutBox() 
{
   // If the instance of the ActiveX control is null when the AboutBox method 
   // is called, raise an InvalidActiveXStateException exception.
   if ((this.ocx == null)) 
   {
      throw new System.Windows.Forms.AxHost.InvalidActiveXStateException(
        "AboutBox", System.Windows.Forms.AxHost.ActiveXInvokeKind.MethodInvoke);
   }
   // Show the about box if the ActiveX control has one.
   if(this.HasAboutBox)
   {
      this.ocx.AboutBox();
   }
}

protected override void AttachInterfaces() 
{
   try 
   {
      // Attach the IMSMask interface to the ActiveX control.
      this.ocx = ((MSMask.IMSMask)(this.GetOcx()));
   }
   catch (System.Exception ex) 
   {
      System.Console.WriteLine(ex.Message);
   }
}

[Visual Basic, C++, JScript] Visual Basic、C++、および JScript のサンプルはありません。C# のサンプルを表示するには、このページの左上隅にある言語のフィルタ ボタン 言語のフィルタ をクリックします。

必要条件

名前空間: System.Windows.Forms

プラットフォーム: Windows 98, Windows NT 4.0, Windows Millennium Edition, Windows 2000, Windows XP Home Edition, Windows XP Professional, Windows Server 2003 ファミリ

アセンブリ: System.Windows.Forms (System.Windows.Forms.dll 内)

参照

AxHost.InvalidActiveXStateException メンバ | System.Windows.Forms 名前空間 | AxHost.ActiveXInvokeKind