/**************************************************************************** ** ** Copyright (C) 1992-2008 Trolltech ASA. All rights reserved. ** ** This file is part of an example program for TQt. This example ** program may be used, distributed and modified without limitation. ** *****************************************************************************/ #include "lineedits.h" #include <tqlineedit.h> #include <tqcombobox.h> #include <tqframe.h> #include <tqvalidator.h> #include <tqlabel.h> #include <tqlayout.h> #include <tqhbox.h> /* * Constructor * * Creates child widgets of the LineEdits widget */ LineEdits::LineEdits( TQWidget *parent, const char *name ) : TQGroupBox( 0, Horizontal, "Line edits", parent, name ) { setMargin( 10 ); TQVBoxLayout* box = new TQVBoxLayout( layout() ); TQHBoxLayout *row1 = new TQHBoxLayout( box ); row1->setMargin( 5 ); // Create a Label TQLabel* label = new TQLabel( "Echo Mode: ", this); row1->addWidget( label ); // Create a Combobox with three items... combo1 = new TQComboBox( FALSE, this ); row1->addWidget( combo1 ); combo1->insertItem( "Normal" ); combo1->insertItem( "Password" ); combo1->insertItem( "No Echo" ); // ...and connect the activated() TQ_SIGNAL with the slotEchoChanged() TQ_SLOT to be able // to react when an item is selected connect( combo1, TQ_SIGNAL( activated( int ) ), this, TQ_SLOT( slotEchoChanged( int ) ) ); // insert the first LineEdit lined1 = new TQLineEdit( this ); box->addWidget( lined1 ); // another widget which is used for layouting TQHBoxLayout *row2 = new TQHBoxLayout( box ); row2->setMargin( 5 ); // and the second label label = new TQLabel( "Validator: ", this ); row2->addWidget( label ); // A second Combobox with again three items... combo2 = new TQComboBox( FALSE, this ); row2->addWidget( combo2 ); combo2->insertItem( "No Validator" ); combo2->insertItem( "Integer Validator" ); combo2->insertItem( "Double Validator" ); // ...and again the activated() TQ_SIGNAL gets connected with a TQ_SLOT connect( combo2, TQ_SIGNAL( activated( int ) ), this, TQ_SLOT( slotValidatorChanged( int ) ) ); // and the second LineEdit lined2 = new TQLineEdit( this ); box->addWidget( lined2 ); // yet another widget which is used for layouting TQHBoxLayout *row3 = new TQHBoxLayout( box ); row3->setMargin( 5 ); // we need a label for this too label = new TQLabel( "Alignment: ", this ); row3->addWidget( label ); // A combo box for setting alignment combo3 = new TQComboBox( FALSE, this ); row3->addWidget( combo3 ); combo3->insertItem( "Left" ); combo3->insertItem( "Centered" ); combo3->insertItem( "Right" ); // ...and again the activated() TQ_SIGNAL gets connected with a TQ_SLOT connect( combo3, TQ_SIGNAL( activated( int ) ), this, TQ_SLOT( slotAlignmentChanged( int ) ) ); // and the third lineedit lined3 = new TQLineEdit( this ); box->addWidget( lined3 ); // exactly the same for the fourth TQHBoxLayout *row4 = new TQHBoxLayout( box ); row4->setMargin( 5 ); // we need a label for this too label = new TQLabel( "Input mask: ", this ); row4->addWidget( label ); // A combo box for choosing an input mask combo4 = new TQComboBox( FALSE, this ); row4->addWidget( combo4 ); combo4->insertItem( "No mask" ); combo4->insertItem( "Phone number" ); combo4->insertItem( "ISO date" ); combo4->insertItem( "License key" ); // ...this time we use the activated( const TQString & ) signal connect( combo4, TQ_SIGNAL( activated( int ) ), this, TQ_SLOT( slotInputMaskChanged( int ) ) ); // and the fourth lineedit lined4 = new TQLineEdit( this ); box->addWidget( lined4 ); // last widget used for layouting TQHBox *row5 = new TQHBox( this ); box->addWidget( row5 ); row5->setMargin( 5 ); // last label (void)new TQLabel( "Read-Only: ", row5 ); // A combo box for setting alignment combo5 = new TQComboBox( FALSE, row5 ); combo5->insertItem( "False" ); combo5->insertItem( "True" ); // ...and again the activated() TQ_SIGNAL gets connected with a TQ_SLOT connect( combo5, TQ_SIGNAL( activated( int ) ), this, TQ_SLOT( slotReadOnlyChanged( int ) ) ); // and the last lineedit lined5 = new TQLineEdit( this ); box->addWidget( lined5 ); // give the first LineEdit the focus at the beginning lined1->setFocus(); } /* * TQ_SLOT slotEchoChanged( int i ) * * i contains the number of the item which the user has been chosen in the * first Combobox. According to this value, we set the Echo-Mode for the * first LineEdit. */ void LineEdits::slotEchoChanged( int i ) { switch ( i ) { case 0: lined1->setEchoMode( TQLineEdit::Normal ); break; case 1: lined1->setEchoMode( TQLineEdit::Password ); break; case 2: lined1->setEchoMode( TQLineEdit::NoEcho ); break; } lined1->setFocus(); } /* * TQ_SLOT slotValidatorChanged( int i ) * * i contains the number of the item which the user has been chosen in the * second Combobox. According to this value, we set a validator for the * second LineEdit. A validator checks in a LineEdit each character which * the user enters and accepts it if it is valid, else the character gets * ignored and not inserted into the lineedit. */ void LineEdits::slotValidatorChanged( int i ) { switch ( i ) { case 0: lined2->setValidator( 0 ); break; case 1: lined2->setValidator( new TQIntValidator( lined2 ) ); break; case 2: lined2->setValidator( new TQDoubleValidator( -999.0, 999.0, 2, lined2 ) ); break; } lined2->setText( "" ); lined2->setFocus(); } /* * TQ_SLOT slotAlignmentChanged( int i ) * * i contains the number of the item which the user has been chosen in * the third Combobox. According to this value, we set an alignment * third LineEdit. */ void LineEdits::slotAlignmentChanged( int i ) { switch ( i ) { case 0: lined3->setAlignment( TQLineEdit::AlignLeft ); break; case 1: lined3->setAlignment( TQLineEdit::AlignCenter ); break; case 2: lined3->setAlignment( TQLineEdit::AlignRight ); break; } lined3->setFocus(); } /* * TQ_SLOT slotInputMaskChanged( const TQString &mask ) * * i contains the number of the item which the user has been chosen in * the third Combobox. According to this value, we set an input mask on * third LineEdit. */ void LineEdits::slotInputMaskChanged( int i ) { switch( i ) { case 0: lined4->setInputMask( TQString::null ); break; case 1: lined4->setInputMask( "+99 99 99 99 99;_" ); break; case 2: lined4->setInputMask( "0000-00-00" ); lined4->setText( "00000000" ); lined4->setCursorPosition( 0 ); break; case 3: lined4->setInputMask( ">AAAAA-AAAAA-AAAAA-AAAAA-AAAAA;#" ); break; } lined4->setFocus(); } /* * TQ_SLOT slotReadOnlyChanged( int i ) * * i contains the number of the item which the user has been chosen in * the fourth Combobox. According to this value, we toggle read-only. */ void LineEdits::slotReadOnlyChanged( int i ) { switch ( i ) { case 0: lined5->setReadOnly( FALSE ); break; case 1: lined5->setReadOnly( TRUE ); break; } lined5->setFocus(); }