Two simple Qt widgets (in-process)The ActiveX controls in this example are simple QWidget subclasses reimplementing the paintEvent() method. The classes use the Q_CLASSINFO macro toThe example demonstrates the use of the Q_CLASSINFO macro to set ActiveQt-specific attributes for QObject sub classes, and the use of the QAXFACTORY_BEGIN, QAXCLASS and QAXFACTORY_END macros.
class QAxWidget1 : public QWidget { Q_OBJECT Q_CLASSINFO("ClassID", "{1D9928BD-4453-4bdd-903D-E525ED17FDE5}") Q_CLASSINFO("InterfaceID", "{99F6860E-2C5A-42ec-87F2-43396F4BE389}") Q_CLASSINFO("EventsID", "{0A3E9F27-E4F1-45bb-9E47-63099BCCD0E3}")The class declaration includes the Q_OBJECT macro to activate Qt's meta object system, and sets COM identifiers for the class using the Q_CLASSINFO macro. Q_PROPERTY( QColor fillColor READ fillColor WRITE setFillColor ) public: QAxWidget1( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ) : QWidget( parent, name, f ), fill_color( red ) { } QColor fillColor() const { return fill_color; } void setFillColor( const QColor &fc ) { fill_color = fc; repaint(); } protected: void paintEvent( QPaintEvent *e ) { QPainter paint( this ); QRect r = rect();The control draws a filled rectangle. The fill color is exposed as a property using the Q_PROPERTY macro.
class QAxWidget2 : public QWidget { Q_OBJECT Q_CLASSINFO("ClassID", "{58139D56-6BE9-4b17-937D-1B1EDEDD5B71}") Q_CLASSINFO("InterfaceID", "{B66280AB-08CC-4dcc-924F-58E6D7975B7D}") Q_CLASSINFO("EventsID", "{D72BACBA-03C4-4480-B4BB-DE4FE3AA14A0}") Q_CLASSINFO("ToSuperClass", "QAxWidget2") Q_CLASSINFO("StockEvents", "yes")The declaration of the second control class uses the Q_CLASSINFO macro to set the COM identifiers as well as additional COM attributes for the class. Objects of that class will not expose the QWidget API, and provide the ActiveX stock events (ie. Click, KeyDown etc.). Q_PROPERTY( int lineWidth READ lineWidth WRITE setLineWidth ) public: QAxWidget2( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ) : QWidget( parent, name, f ), line_width( 1 ) { } int lineWidth() const { return line_width; } void setLineWidth( int lw ) { line_width = lw; repaint(); } protected: void paintEvent( QPaintEvent *e ) { QPainter paint( this );The control draws a circle. The line width is exposed as a property using the Q_PROPERTY macro. The controls are exposed by the implementation of QAxFactory as provided by the QAXFACTORY_BEGIN and QAXFACTORY_END macros. #include <qaxfactory.h> #include "ax1.h" #include "ax2.h" QAXFACTORY_BEGIN("{98DE28B6-6CD3-4e08-B9FA-3D1DB43F1D2F}", "{05828915-AD1C-47ab-AB96-D6AD1E25F0E2}")The factory is initialied using the QAXFACTORY_BEGIN macro, providing the IDs for the application and the type library. QAXCLASS(QAxWidget1) QAXCLASS(QAxWidget2)The classes exposed are listed using the QAXCLASS macro. QAXFACTORY_END()Finally the factory declaration is closed using the QAXFACTORY_END macro. To build the example you must first build the QAxServer library. Then run qmake and your make tool in examples/multiple.
The demonstration requires your WebBrowser to support ActiveX controls, and scripting to be enabled.
<script language=javascript> function setColor( form ) { Ax1.fillColor = form.colorEdit.value; } function setWidth( form ) { Ax2.lineWidth = form.widthEdit.value; } </script> <p> This is one QWidget subclass:<br> <object ID="Ax1" CLASSID="CLSID:1D9928BD-4453-4bdd-903D-E525ED17FDE5" CODEBASE=http://www.trolltech.com/demos/multipleax.cab> [Object not available! Did you forget to build and register the server?] </object><br> <form> Fill Color: <input type="edit" ID="colorEdit" value = "red"> <input type="button" value = "Set" onClick="setColor(this.form)"> <input type="button" value = "Hide" onClick="Ax1.hide()"> <input type="button" value = "Show" onClick="Ax1.show()"> </form> <p> This is another QWidget subclass:<br> <object ID="Ax2" CLASSID="CLSID:58139D56-6BE9-4b17-937D-1B1EDEDD5B71" CODEBASE=http://www.trolltech.com/demos/multipleax.cab> [Object not available! Did you forget to build and register the server?] </object><br> <form> Line width: <input type="edit" ID="widthEdit" value = "1"> <input type="button" value = "Set" onClick="setWidth(this.form)"> </form> See also The QAxServer Examples. |
Publicité
Best OfActualités les plus luesSemaine
Mois
Année
Le blog Digia au hasardDéploiement d'applications Qt Commercial sur les tablettes Windows 8Le blog Digia est l'endroit privilégié pour la communication sur l'édition commerciale de Qt, où des réponses publiques sont apportées aux questions les plus posées au support. Lire l'article.
CommunautéRessources
Liens utilesContact
Qt dans le magazine |
Cette page est une traduction d'une page de la documentation de Qt, écrite par Nokia Corporation and/or its subsidiary(-ies). Les éventuels problèmes résultant d'une mauvaise traduction ne sont pas imputables à Nokia. | Qt 3.3 | |
Copyright © 2012 Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon, vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD. | ||
Vous avez déniché une erreur ? Un bug ? Une redirection cassée ? Ou tout autre problème, quel qu'il soit ? Ou bien vous désirez participer à ce projet de traduction ? N'hésitez pas à nous contacter ou par MP ! |
Copyright © 2000-2012 - www.developpez.com