Пример "Simple" (ActiveQt)
Файлы: Пример "Simple" демонстрирует использование QAxBindable::requestPropertyChange() и QAxBindable::propertyChanged(), и использование по умолчанию QAxFactory посредством макроса QAXFACTORY_DEFAULT(). Элемент управления ActiveX в этом примере - размещенный QWidget с QSlider, QLCDNumber и QLineEdit. Он предоставляет интерфейс сигнал/слот/свойство для изменения значений ползунка и однострочного поля ввода, а также для получения уведомлений о любых изменениях свойства. Реализация Qt ActiveX для этого примера class QSimpleAX : public QWidget, public QAxBindable { Q_OBJECT Q_PROPERTY( QString text READ text WRITE setText ) Q_PROPERTY( int value READ value WRITE setValue ) public: QSimpleAX(QWidget *parent = 0) : QWidget(parent) { QVBoxLayout *vbox = new QVBoxLayout( this ); slider = new QSlider( Qt::Horizontal, this ); LCD = new QLCDNumber( 3, this ); edit = new QLineEdit( this ); connect( slider, SIGNAL( valueChanged( int ) ), this, SLOT( setValue(int) ) ); connect( edit, SIGNAL(textChanged(const QString&)), this, SLOT(setText(const QString&)) ); vbox->addWidget( slider ); vbox->addWidget( LCD ); vbox->addWidget( edit ); } QString text() const { return edit->text(); } int value() const { return slider->value(); } signals: void someSignal(); void valueChanged(int); void textChanged(const QString&); public slots: void setText( const QString &string ) { if ( !requestPropertyChange( "text" ) ) return; edit->blockSignals( true ); edit->setText( string ); edit->blockSignals( false ); emit someSignal(); emit textChanged( string ); propertyChanged( "text" ); } void about() { QMessageBox::information( this, "About QSimpleAX", "This is a Qt widget, and this slot has been\n" "called through ActiveX/OLE automation!" ); } void setValue( int i ) { if ( !requestPropertyChange( "value" ) ) return; slider->blockSignals( true ); slider->setValue( i ); slider->blockSignals( false ); LCD->display( i ); emit valueChanged( i ); propertyChanged( "value" ); } private: QSlider *slider; QLCDNumber *LCD; QLineEdit *edit; }; Элемент управления экспортируется используя по умолчанию QAxFactory QAXFACTORY_DEFAULT(QSimpleAX, "{DF16845C-92CD-4AAB-A982-EB9840E74669}", "{616F620B-91C5-4410-A74E-6B81C76FFFE0}", "{E1816BBA-BF5D-4A31-9855-D6BA432055FF}", "{EC08F8FC-2754-47AB-8EFE-56A54057F34E}", "{A095BA0C-224F-4933-A458-2DD7F6B85D8F}") Чтобы собрать пример вы должны сначала собрать библиотеку QAxServer. Затем запустите qmake и ваш make-инструмент в каталоге examples/activeqt/simple. Демонстрационная программа требует поддержки элементов управления ActiveX в вашем веб-браузере, а также разрешения выполнения сценариев. Простой элемент управления ActiveX встраивается используя тег <object>. <object ID="QSimpleAX" CLASSID="CLSID:DF16845C-92CD-4AAB-A982-EB9840E74669" CODEBASE="http://www.trolltech.com/demos/simpleax.cab"> <PARAM NAME="text" VALUE="A simple control" /> <PARAM NAME="value" VALUE="1" /> [Object not available! Did you forget to build and register the server?] </object> Простая кнопка HTML соединяется со слотом ActiveQt'а - about(). <FORM> <INPUT TYPE="BUTTON" VALUE="About..." onClick="QSimpleAX.about()" /> </FORM> Второй элемент управления ActiveX - стандартный Calendar Control - подвергается обработке <object ID="Calendar" CLASSID="CLSID:8E27C92B-1264-101C-8A2F-040224009C02"> [Standard Calendar control not available!] <PARAM NAME="day" VALUE="1" /> </object> События из элементов управления ActiveX обрабатываются используя и Visual Basic Script, и JavaScript. <SCRIPT LANGUAGE="VBScript"> Sub Calendar_Click() MsgBox( "Calendar Clicked!" ) End Sub Sub QSimpleAX_TextChanged( str ) document.title = str End Sub </SCRIPT> <SCRIPT LANGUAGE="JavaScript"> function QSimpleAX::ValueChanged( Newvalue ) { Calendar.Day = Newvalue; } </SCRIPT>
|
Попытка перевода Qt документации. Если есть желание присоединиться, или если есть замечания или пожелания, то заходите на форум: Перевод Qt документации на русский язык... Люди внесшие вклад в перевод: Команда переводчиков |