Пример "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://qt.nokia.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>
Copyright © 2009 Nokia Corporation and/or its subsidiary(-ies) |
Торговые марки |
Qt 4.5.3 |
|