QAxWidget Class

QAxWidgetクラスは、ActiveXコントロールをラップするQWidget詳細...

Header: #include <QAxWidget>
CMake: find_package(Qt6 REQUIRED COMPONENTS AxContainer)
target_link_libraries(mytarget PRIVATE Qt6::AxContainer)
qmake: QT += axcontainer
Inherits: QAxBaseWidget and QAxBase

パブリック関数

QAxWidget(QWidget *parent = nullptr, Qt::WindowFlags f = Qt::WindowFlags())
QAxWidget(IUnknown *iface, QWidget *parent = nullptr, Qt::WindowFlags f = Qt::WindowFlags())
QAxWidget(const QString &c, QWidget *parent = nullptr, Qt::WindowFlags f = Qt::WindowFlags())
virtual ~QAxWidget() override
void clear()
virtual QAxAggregated *createAggregate()
bool doVerb(const QString &verb)

再実装パブリック関数

virtual QSize minimumSizeHint() const override
virtual void resetControl() override
virtual QSize sizeHint() const override

保護された関数

virtual bool createHostWindow(bool initialized)
bool createHostWindow(bool initialized, const QByteArray &data)
virtual bool translateKeyEvent(int message, int keycode) const

再実装された保護された関数

virtual void changeEvent(QEvent *e) override
virtual void connectNotify(const QMetaMethod &signal) override
virtual bool initialize(IUnknown **ptr) override
virtual void resizeEvent(QResizeEvent *) override

詳細説明

QAxWidgetは、空のオブジェクト、ラップするActiveXコントロールの名前、またはActiveXコントロールへの既存のインターフェイスポインタとしてインスタンス化することができます。ActiveXコントロールのプロパティ、メソッド、イベントは、QAxBase でサポートされているデータ型のみを使用し、Qtプロパティ、スロット、シグナルとして使用できるようになります。基本クラスQAxBase は、IUnknown ポインタを通して ActiveX に直接アクセスするための API を提供します。

QAxWidgetはQWidget 、ほとんどの場合そのように使用することができます。例えば、ウィジェットの階層やレイアウトを整理したり、イベントフィルターとして動作させることができます。標準的なウィジェット・プロパティ、例えばenabled がサポートされていますが、パレットやフォントなどのアンビエント・プロパティのサポートはActiveXコントロールに依存します。QAxWidgetは必要なヒントを提供しようとします。

しかし、mousePressEventやkeyPressEventのようなQt固有のイベントハンドラを再実装し、確実に呼び出されることを期待することはできません。組み込みコントロールは、QAxWidgetを完全にカバーし、通常はユーザーインターフェイス自体を処理します。コントロール固有のAPI(つまり、コントロールのシグナルをリッスンする)を使用するか、ウィンドウプロシージャのサブクラス化のような標準的なCOMテクニックを使用してください。

QAxWidgetはまた、ActiveX関連の機能のほとんどをQAxBase 、特にdynamicCall ()とquerySubObject ()から継承しています。

警告 QAxWidgetをサブクラス化することは可能ですが、サブクラス内でQ_OBJECT マクロを使用することはできません(生成されたmocファイルはコンパイルされません)ので、シグナル、スロット、プロパティを追加することはできません。この制限は、実行時に生成されるメタオブジェクト情報によるものです。この問題を回避するには、QObject サブクラスのメンバとして QAxWidget を集約します。

QAxBase,QAxObject,QAxScript,ActiveQt Frameworkも参照してください

メンバー関数ドキュメント

[explicit] QAxWidget::QAxWidget(QWidget *parent = nullptr, Qt::WindowFlags f = Qt::WindowFlags())

空の QAxWidget ウィジェットを作成し、parentfQWidget コンストラクタに伝搬します。コントロールを初期化するには、setControl() を呼び出します。

[explicit] QAxWidget::QAxWidget(IUnknown *iface, QWidget *parent = nullptr, Qt::WindowFlags f = Qt::WindowFlags())

iface によって参照される COM オブジェクトをラップする QAxWidget を作成します。parentfQWidget コンストラクタに伝搬されます。

[explicit] QAxWidget::QAxWidget(const QString &c, QWidget *parent = nullptr, Qt::WindowFlags f = Qt::WindowFlags())

QAxWidget ウィジェットを作成し、ActiveX コントロールc を初期化します。parent およびf は、QWidget コンストラクタに伝搬されます。

setControl()も参照してください

[override virtual noexcept] QAxWidget::~QAxWidget()

ActiveX コントロールをシャットダウンし、QAxWidget ウィジェットを破棄して、割り当てられたすべてのリソースをクリーンアップします。

clear() も参照

[override virtual protected] void QAxWidget::changeEvent(QEvent *e)

再インプリメント:QWidget::changeEvent(QEvent *event)。

void QAxWidget::clear()

ActiveX コントロールをシャットダウンします。

resetControl() も参照して ください。

[override virtual protected] void QAxWidget::connectNotify(const QMetaMethod &signal)

再リンプルメント: (QMetaMethod &signal):QObject::connectNotify(const QMetaMethod &signal)。

[virtual] QAxAggregated *QAxWidget::createAggregate()

ActiveXコントロールのクライアント・サイト用に追加のCOMインタフェースを実装する場合や、COMインタフェースの代替実装を提供する場合に、この関数を再実装します。QAxAggregated サブクラスの新しいオブジェクトを返します。

デフォルトの実装では、NULL ポインタを返します。

[virtual protected] bool QAxWidget::createHostWindow(bool initialized)

ActiveXコントロールのクライアント・サイトを作成し、コントロールが正常に埋め込まれた場合はtrueを返し、そうでない場合はfalseを返します。そうでなければfalseを返す。initialized がtrueの場合、コントロールはすでに初期化されている。

この関数はinitialize() から呼び出される。実際のコントロールのインスタンス化をカスタマイズするためにinitializeを再実装する場合は、再実装の中でこの関数を呼び出し、デフォルトのクライアント側でコントロールを埋め込みます。ActiveXコントロールのクライアント・サイトを作成し、コントロールが正常に埋め込まれた場合はtrueを返し、そうでない場合はfalseを返します。

[protected] bool QAxWidget::createHostWindow(bool initialized, const QByteArray &data)

ActiveXコントロールのクライアント・サイトを作成し、コントロールが正常に埋め込まれた場合はtrueを返し、そうでない場合はfalseを返します。initialized が False の場合、コントロールはdata を使用して初期化される。 コントロールは、IPersistStreamInit または IPersistStorage インターフェースで初期化される。

カスタム・データを使用してコントロールを初期化する必要がある場合は、initialize() の再実装でこの関数を呼び出してください。この関数は、initialize() のデフォルト実装では呼び出されません。

bool QAxWidget::doVerb(const QString &verb)

ActiveX コントロールにアクションの実行を要求しますverb 。実行可能な動詞は、verbs() によって返されます。

この関数は、オブジェクトがアクションを実行できる場合は true を返し、そうでない場合は false を返します。

[override virtual protected] bool QAxWidget::initialize(IUnknown **ptr)

再実装:QAxBase::initialize(IUnknown **ptr)。

QAxBase::initialize(ptr) を呼び出し、成功すればcreateHostWindow(false) を呼び出してコントロールをこのウィジェットに埋め込みます。

コントロールがアクティブになる前に初期化するには、この関数を再実装し、createHostWindow(true)を呼び出す前に初期化コードを追加します。

成功した場合はtrue を返し、そうでない場合はfalse を返します。

[override virtual] QSize QAxWidget::minimumSizeHint() const

プロパティのアクセス関数を再実装します:QWidget::minimumSizeHint

[override virtual] void QAxWidget::resetControl()

再実装します:QAxObjectInterface::resetControl().

ActiveX コントロールをシャットダウンします。

[override virtual protected] void QAxWidget::resizeEvent(QResizeEvent *)

を再実装します:QWidget::resizeEvent(QResizeEvent *event)。

[override virtual] QSize QAxWidget::sizeHint() const

プロパティのアクセス関数を再実装します:QWidget::sizeHint

[virtual protected] bool QAxWidget::translateKeyEvent(int message, int keycode) const

特定のキーイベントをActiveXコントロールに渡すために、この関数を再実装します。message は、メッセージタイプを指定するWindowメッセージ識別子(例:WM_KEYDOWN)であり、keycode は、仮想キーコード(例:VK_TAB)です。

この関数がtrueを返した場合、キーイベントはActiveXコントロールに渡され、ActiveXコントロールはイベントを処理するか、Qtにイベントを渡します。

関数がfalseを返した場合、キーイベントの処理はActiveQtによって無視されます。

デフォルトの実装では、以下の場合に true を返します:

WM_SYSKEYDOWNWM_SYSKEYUPWM_KEYDOWN
すべてのキーコードVK_MENUVK_TAB、VK_DELETE、およびVK_SHIFT、VK_CONTROL、またはVK_MENUと組み合わせた矢印キー以外のすべてのキー。

この表は、一般的なActiveXコントロール、例えばInternet ExplorerやMicrosoft Officeアプリケーションで実験した結果です。

©2024 The Qt Company Ltd. 本書に含まれるドキュメントの著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。