diff options
author | Michele Calgaro <[email protected]> | 2023-07-07 16:31:18 +0900 |
---|---|---|
committer | Michele Calgaro <[email protected]> | 2023-07-07 16:31:18 +0900 |
commit | 7c116f3bf7ce2c552af7dd8709ee6e726844ef20 (patch) | |
tree | 559fdbc61c80b61ee9d8d99bd8234ddeb1aff394 | |
parent | bfd62a0bbfd44ce5f7530fc7bb624dd911f9033a (diff) | |
download | tqt3-7c116f3bf7ce2c552af7dd8709ee6e726844ef20.tar.gz tqt3-7c116f3bf7ce2c552af7dd8709ee6e726844ef20.zip |
Drop attic Qt2 classes (TQtMultiLineEdit and TQtTableView)
Signed-off-by: Michele Calgaro <[email protected]>
-rw-r--r-- | src/.tmp/README | 1 | ||||
-rw-r--r-- | src/attic/README | 6 | ||||
-rw-r--r-- | src/attic/qtmultilineedit.cpp | 4236 | ||||
-rw-r--r-- | src/attic/qtmultilineedit.h | 363 | ||||
-rw-r--r-- | src/attic/qttableview.cpp | 2272 | ||||
-rw-r--r-- | src/attic/qttableview.h | 250 |
6 files changed, 0 insertions, 7128 deletions
diff --git a/src/.tmp/README b/src/.tmp/README deleted file mode 100644 index 9d010df3b..000000000 --- a/src/.tmp/README +++ /dev/null @@ -1 +0,0 @@ -This directory contains only generated files. diff --git a/src/attic/README b/src/attic/README deleted file mode 100644 index 2e60ebce5..000000000 --- a/src/attic/README +++ /dev/null @@ -1,6 +0,0 @@ -This directory contains classes that has been obsoleted and moved out -of the TQt API. - -To use these classes, simply include them in your project. Remember to -rename the class references in your own code. - diff --git a/src/attic/qtmultilineedit.cpp b/src/attic/qtmultilineedit.cpp deleted file mode 100644 index 0f52e6cf6..000000000 --- a/src/attic/qtmultilineedit.cpp +++ /dev/null @@ -1,4236 +0,0 @@ -/********************************************************************** -** -** Implementation of TQtMultiLineEdit widget class -** -** Created : 961005 -** -** Copyright (C) 1992-2008 Trolltech ASA. All rights reserved. -** -** This file contains a class moved out of the TQt GUI Toolkit API. It -** may be used, distributed and modified without limitation. -** -**********************************************************************/ - -#include "qtmultilineedit.h" -#ifndef TQT_NO_QTMULTILINEEDIT -#include "ntqpainter.h" -#include "ntqscrollbar.h" -#include "ntqclipboard.h" -#include "ntqpixmap.h" -#include "ntqregexp.h" -#include "ntqapplication.h" -#include "ntqdragobject.h" -#include "ntqpopupmenu.h" -#include "ntqtimer.h" -#include "ntqdict.h" -#include "ntqcursor.h" -#ifndef TQT_NO_COMPAT -#include "ntqstyle.h" -#endif - - -class TQtMultiLineEditCommand -{ -public: - enum Commands { Invalid, Begin, End, Insert, Delete }; - virtual ~TQtMultiLineEditCommand() {}; - virtual Commands type() { return Invalid; }; - virtual int terminator() { return 0; } - - virtual bool merge( TQtMultiLineEditCommand* ) { return FALSE;} -}; - -class TQBeginCommand : public TQtMultiLineEditCommand -{ - -public: - TQBeginCommand() {} - int terminator() { return 1; } - Commands type() { return Begin; }; -}; - -class TQEndCommand : public TQtMultiLineEditCommand -{ -public: - TQEndCommand() {} - int terminator() { return -1; } - Commands type() { return End; }; -}; - -// TQtMultiLineEditUndoRedo methods -class TQDelTextCmd : public TQtMultiLineEditCommand -{ -public: - int mOffset; - TQString mStr; - - // have to handle deletion of current selection - TQDelTextCmd(int offset, const TQString &str ) - : mOffset( offset ), - mStr ( str ) - { - } - Commands type() { return Delete; }; - - bool merge( TQtMultiLineEditCommand* other) - { - if ( other->type() == type() ) { - TQDelTextCmd* o = (TQDelTextCmd*) other; - if ( mOffset + int(mStr.length()) == o->mOffset ) { - o->mStr.prepend( mStr ); - o->mOffset = mOffset; - return TRUE; - } - } - return FALSE; - } - - -}; - -class TQInsTextCmd : public TQDelTextCmd -{ - -public: - TQInsTextCmd(int offset,const TQString &str ) - : TQDelTextCmd( offset, str ) - { - } - - Commands type() { return Insert; }; - - bool merge( TQtMultiLineEditCommand* other) - { - if ( other->type() == type() ) { - TQInsTextCmd* o = (TQInsTextCmd*) other; - if ( mOffset == o->mOffset + int(o->mStr.length()) ) { - o->mStr += mStr; - return TRUE; - } - } - return FALSE; - } -}; - - -/* - \class TQtMultiLineEdit qtmultilineedit.h - - \brief The TQtMultiLineEdit widget is a simple editor for inputting text. - - \obsolete - - The TQtMultiLineEdit widget provides multiple line text input and display. - It is intended for moderate amounts of text. There are no arbitrary - limitations, but if you try to handle megabytes of data, performance - will suffer. - - Per default, the edit widget does not perform any word - wrapping. This can be adjusted by calling setWordWrap(). Both - dynamic wrapping according to the visible width or a fixed number of - character or pixels is supported. - - The widget can be used to display text by calling setReadOnly(TRUE). - - The default key bindings are described in keyPressEvent(); they cannot - be customized except by inheriting the class. - - <img src=qmlined-m.png> <img src=qmlined-w.png> -*/ - -/* - \property TQtMultiLineEdit::numLines - \brief the number of lines in the multi-line edit - - numLines() returns the number of lines in the editor. The count - includes any empty lines at top and bottom, so for an empty editor - this method will return 1. -*/ -/* - \property TQtMultiLineEdit::atBeginning - \brief whether the cursor is at the beginning - - atBeginning() returns TRUE if the cursor is placed at the - beginning of the text. -*/ -/* - \property TQtMultiLineEdit::atEnd - \brief whether the cursor is at the end - - atEnd() returns TRUE if the cursor is placed at the end of the text. -*/ -/* - \property TQtMultiLineEdit::maxLineWidth - \brief the maximum line width in pixels - Returns the width in pixels of the longest text line in this editor. -*/ -/* - \property TQtMultiLineEdit::alignment - \brief the alignment - - Possible values are \c AlignLeft, \c Align(H)Center and \c - AlignRight. - \sa TQt::AlignmentFlags -*/ -/* - \property TQtMultiLineEdit::edited - \brief whether the text had been edited - -edited() returns the edited flag of the line edit. If this returns FALSE, -the contents has not been changed since the construction of the -TQtMultiLineEdit (or the last call to setEdited( FALSE ), if any). If -it returns TRUE, the contents have been edited, or setEdited( TRUE ) -has been called. - -setEdited() sets the edited flag of this line edit to \e e. The -edited flag is never read by TQtMultiLineEdit, but is changed to TRUE -whenever the user changes its contents. - -This is useful e.g. for things that need to provide a default value, -but cannot find the default at once. Just open the widget without the -best default and when the default is known, check the edited() return -value and set the line edit's contents if the user has not started -editing the line edit. Another example is to detect whether the -contents need saving. - -*/ -/* - \property TQtMultiLineEdit::echoMode - \brief the echo mode -*/ -/* - \property TQtMultiLineEdit::maxLength - \brief the maximum length of the text - - The currently set text length limit, or -1 if there is - no limit (this is the default). - -*/ -/* - \property TQtMultiLineEdit::maxLines - \brief the maximum number of lines - The currently set line limit, or -1 if there is - no limit (the default). - - Note that excess lines are deleted from the \e bottom of the - lines. If you want teletype behaviour with lines disappearing - from the \e top as the limit is exceed, you probably just want - to use removeLine(0) prior to adding an excess line. - -*/ -/* - \property TQtMultiLineEdit::hMargin - \brief the horizontal margin - The horizontal margin current set. The default is 3. -*/ -/* - \property TQtMultiLineEdit::wordWrap - \brief the word wrap mode - - By default, wrapping keeps words intact. To allow breaking within - words, set the wrap policy to \c Anywhere (see setWrapPolicy() ). - - The default wrap mode is \c NoWrap. - - \sa wordWrap(), setWrapColumnOrWidth(), setWrapPolicy() -*/ -/* - \property TQtMultiLineEdit::wrapColumnOrWidth - \brief the wrap width in columns or pixels - The wrap column or wrap width, depending on the word wrap - mode. - \sa setWordWrap(), setWrapColumnOrWidth() -*/ -/* - \property TQtMultiLineEdit::wrapPolicy - \brief the wrap policy mode - The default is \c AtWhiteSpace. - -*/ -/* - \property TQtMultiLineEdit::autoUpdate - \brief whether auto update is enabled - - autoUpdate() returns TRUE if the view updates itself automatically - whenever it is changed in some way. - - If autoUpdate() is TRUE (this is the default) then the editor updates - itself automatically whenever it has changed in some way (generally, - when text has been inserted or deleted). - - If autoUpdate() is FALSE, the view does NOT repaint itself, or update - its internal state variables itself when it is changed. This can be - useful to avoid flicker during large changes, and is singularly - useless otherwise: Disable auto-update, do the changes, re-enable - auto-update, and call repaint(). - - \warning Do not leave the view in this state for a long time - (i.e. between events ). If, for example, the user interacts with the - view when auto-update is off, strange things can happen. - - Setting auto-update to TRUE does not repaint the view, you must call - repaint() to do this (preferable repaint(FALSE) to avoid flicker). - - \sa autoUpdate() repaint() - -*/ -/* - \property TQtMultiLineEdit::undoEnabled - \brief whether undo is enabled -*/ -/* - \property TQtMultiLineEdit::undoDepth - \brief the undo depth - - The maximum number of operations that can be stored on the undo stack. - - \sa setUndoDepth() -*/ -/* - \property TQtMultiLineEdit::readOnly - \brief whether the multi-line edit is read-only -*/ -/* - \property TQtMultiLineEdit::overWriteMode - \brief the overwrite mode -*/ -/* - \property TQtMultiLineEdit::text - \brief the multi-line edit's text -*/ -/* - \property TQtMultiLineEdit::length - \brief the length of the text -*/ - -static const char * const arrow_xpm[] = { - " 8 8 2 1", - ". c None", - "# c #000000", - "........", - "..####..", - "..#####.", - ".....##.", - ".#..###.", - ".#####..", - ".####...", - ".#####.." -}; - -enum { - IdUndo, - IdRedo, -#ifndef TQT_NO_CLIPBOARD - IdCut, - IdCopy, - IdPaste, - IdPasteSpecial, -#endif - IdClear, - IdSelectAll, - IdCount -}; - -struct TQtMultiLineData -{ - TQtMultiLineData() : - isHandlingEvent(FALSE), - edited(FALSE), - maxLineWidth(0), - align(TQt::AlignLeft), - maxlines(-1), - maxlinelen(-1), - maxlen(-1), - wordwrap( TQtMultiLineEdit::NoWrap ), - wrapcol( -1 ), - wrappolicy( TQtMultiLineEdit::AtWhiteSpace ), - // This doesn't use font bearings, as textWidthWithTabs does that. - // This is just an aesthetics value. - // It should probably be TQMAX(0,3-fontMetrics().minLeftBearing()) though, - // as bearings give some border anyway. - lr_marg(3), - marg_extra(0), - echomode(TQtMultiLineEdit::Normal), - val(0), - dnd_primed(FALSE), - dnd_forcecursor(FALSE), - undo( TRUE ), - undodepth( 256 ) - { - undoList.setAutoDelete( TRUE ); - redoList.setAutoDelete( TRUE ); - clearChartable(); - } - bool isHandlingEvent; - bool edited; - int maxLineWidth; - int scrollTime; - int scrollAccel; - int align; - int numlines; - int maxlines; - int maxlinelen; - int maxlen; - TQtMultiLineEdit::WordWrap wordwrap; - int wrapcol; - TQtMultiLineEdit::WrapPolicy wrappolicy; - int lr_marg; - int marg_extra; - TQtMultiLineEdit::EchoMode echomode; - const TQValidator* val; - - bool dnd_primed; // If TRUE, user has pressed - bool dnd_forcecursor; // If TRUE show cursor for DND feedback, - // even if !hasFocus() - TQPtrList<TQtMultiLineEditCommand> undoList; - TQPtrList<TQtMultiLineEditCommand> redoList; - bool undo; - int undodepth; - short chartable[256]; - void clearChartable() - { - int i = 256; - while ( i ) - chartable[--i] = 0; - } - TQPixmap arrow; - TQPoint dnd_startpos; - TQTimer *blinkTimer, *scrollTimer; -#ifndef TQT_NO_DRAGANDDROP - TQTimer *dnd_timer; -#endif -}; - - -#define CLEAR_UNDO {d->undoList.clear(); emit undoAvailable( FALSE );\ - d->redoList.clear(); emit redoAvailable( FALSE );} - -void TQtMultiLineEdit::addUndoCmd(TQtMultiLineEditCommand* c) -{ - if ( d->undoList.isEmpty() ) - emit undoAvailable(TRUE); - else if ( c->merge( d->undoList.last() ) ) { - delete c; - return; - } - if ( int(d->undoList.count()) >= d->undodepth ) - d->undoList.removeFirst(); - d->undoList.append(c); - - if ( !d->redoList.isEmpty() ) { - d->redoList.clear(); - emit redoAvailable( FALSE ); - } -} - -void TQtMultiLineEdit::addRedoCmd(TQtMultiLineEditCommand* c) -{ - if ( d->redoList.isEmpty() ) - emit redoAvailable(TRUE); - d->redoList.append(c); -} - -static const int initialScrollTime = 50; // mark text scroll time -static const int initialScrollAccel = 5; // mark text scroll accel (0=fastest) -static const int scroll_margin = 16; // auto-scroll edge in DND - -#define WORD_WRAP ( d->wordwrap != TQtMultiLineEdit::NoWrap ) -#define DYNAMIC_WRAP ( d->wordwrap == TQtMultiLineEdit::WidgetWidth ) -#define FIXED_WIDTH_WRAP ( d->wordwrap == TQtMultiLineEdit::FixedPixelWidth ) -#define FIXED_COLUMN_WRAP ( d->wordwrap == TQtMultiLineEdit::FixedColumnWidth ) -#define BREAK_WITHIN_WORDS ( d->wrappolicy == TQtMultiLineEdit::Anywhere ) - -static int defTabStop = 8; - -static int tabStopDist( const TQFontMetrics &fm ) -{ - int dist; - dist = fm.width( TQChar('x' )); - if( dist == 0 ) - dist = fm.maxWidth(); - return defTabStop*dist; -} - - -/* - Sets the distance between tab stops for all TQtMultiLineEdit instances - to \a ex, which is measured in multiples of the width of a lower case 'x' - in the widget's font. The initial value is 8. - - \warning This function does not cause a redraw. It is best to call - it before any TQtMultiLineEdit widgets are shown. - - \sa defaultTabStop() -*/ - -void TQtMultiLineEdit::setDefaultTabStop( int ex ) -{ - defTabStop = ex; -} - - - -/* - Returns the distance between tab stops. - - \sa setDefaultTabStop(); -*/ - -int TQtMultiLineEdit::defaultTabStop() -{ - return defTabStop; -} - - - - -static int textWidthWithTabs( const TQFontMetrics &fm, const TQString &s, uint start, uint nChars, int align ) -{ - if ( s.isEmpty() ) - return 0; - - int dist = -fm.leftBearing( s[(int)start] ); - int i = start; - int tabDist = -1; // lazy eval - while ( (uint)i < s.length() && (uint)i < start+nChars ) { - if ( s[i] == '\t' && align == TQt::AlignLeft ) { - if ( tabDist<0 ) - tabDist = tabStopDist(fm); - dist = ( (dist+tabDist+1)/tabDist ) * tabDist; - i++; - } else { - int ii = i; - while ( (uint)i < s.length() && (uint)i < start + nChars && ( align != TQt::AlignLeft || s[i] != '\t' ) ) - i++; - dist += fm.width( s.mid(ii,i-ii) ); - } - } - return dist; -} - -static int xPosToCursorPos( const TQString &s, const TQFontMetrics &fm, - int xPos, int width, int align ) -{ - int i = 0; - int dist; - int tabDist; - - if ( s.isEmpty() ) - return 0; - if ( xPos > width ) - xPos = width; - if ( xPos <= 0 ) - return 0; - - dist = -fm.leftBearing( s[0] ); - - if ( align == TQt::AlignCenter || align == TQt::AlignHCenter ) - dist = ( width - textWidthWithTabs( fm, s, 0, s.length(), align ) ) / 2; - else if ( align == TQt::AlignRight ) - dist = width - textWidthWithTabs( fm, s, 0, s.length(), align ); - - int distBeforeLastTab = dist; - tabDist = tabStopDist(fm); - while ( (uint)i < s.length() && dist < xPos ) { - if ( s[i] == '\t' && align == TQt::AlignLeft ) { - distBeforeLastTab = dist; - dist = (dist/tabDist + 1) * tabDist; - } else { - dist += fm.width( s[i] ); - } - i++; - } - if ( dist > xPos ) { - if ( dist > width ) { - i--; - } else { - if ( s[i-1] == '\t' && align == TQt::AlignLeft ) { // dist equals a tab stop position - if ( xPos - distBeforeLastTab < (dist - distBeforeLastTab)/2 ) - i--; - } else { - if ( fm.width(s[i-1])/2 < dist-xPos ) - i--; - } - } - } - return i; -} - -/* - Constructs a new, empty, TQtMultiLineEdit with parent \a parent and - called \a name. -*/ - -TQtMultiLineEdit::TQtMultiLineEdit( TQWidget *parent , const char *name ) - :TQtTableView( parent, name, WStaticContents | WRepaintNoErase ) -{ - d = new TQtMultiLineData; - TQFontMetrics fm( font() ); - setCellHeight( fm.lineSpacing() ); - setNumCols( 1 ); - - contents = new TQPtrList<TQtMultiLineEditRow>; - contents->setAutoDelete( TRUE ); - - cursorX = 0; cursorY = 0; - curXPos = 0; - - setTableFlags( Tbl_autoVScrollBar|Tbl_autoHScrollBar| - Tbl_smoothVScrolling | - Tbl_clipCellPainting - ); - setFrameStyle( TQFrame::WinPanel | TQFrame::Sunken ); - setBackgroundMode( PaletteBase ); - setWFlags( WResizeNoErase ); - setKeyCompression( TRUE ); - setFocusPolicy( WheelFocus ); -#ifndef TQT_NO_CURSOR - setCursor( ibeamCursor ); - verticalScrollBar()->setCursor( arrowCursor ); - horizontalScrollBar()->setCursor( arrowCursor ); -#endif - readOnly = FALSE; - cursorOn = FALSE; - markIsOn = FALSE; - dragScrolling = FALSE; - dragMarking = FALSE; - textDirty = FALSE; - wordMark = FALSE; - overWrite = FALSE; - markAnchorX = 0; - markAnchorY = 0; - markDragX = 0; - markDragY = 0; - d->blinkTimer = new TQTimer( this ); - connect( d->blinkTimer, SIGNAL( timeout() ), - this, SLOT( blinkTimerTimeout() ) ); - d->scrollTimer = new TQTimer( this ); - connect( d->scrollTimer, SIGNAL( timeout() ), - this, SLOT( scrollTimerTimeout() ) ); -#ifndef TQT_NO_DRAGANDDROP - d->dnd_timer = new TQTimer( this ); - connect( d->dnd_timer, SIGNAL( timeout() ), - this, SLOT( dndTimeout() ) ); -#endif - d->scrollTime = 0; - - dummy = TRUE; - - int w = textWidth( TQString::fromLatin1("") ); - contents->append( new TQtMultiLineEditRow(TQString::fromLatin1(""), w) ); - (void)setNumRowsAndTruncate(); - setWidth( w ); - setAcceptDrops(TRUE); - if ( d->maxlines >= 0 && d->maxlines <= 6 ) { - setSizePolicy( TQSizePolicy( TQSizePolicy::Expanding, TQSizePolicy::Fixed ) ); - } else { - setSizePolicy( TQSizePolicy( TQSizePolicy::Expanding, TQSizePolicy::Expanding ) ); - } -} - -/* - \fn int TQtMultiLineEdit::lineLength( int line ) const - Returns the number of characters at line number \a line. -*/ - -/* \fn TQString *TQtMultiLineEdit::getString( int line ) const - - Returns a pointer to the text at line \a line. -*/ - -/* \fn void TQtMultiLineEdit::textChanged() - - This signal is emitted when the text is changed by an event or by a - slot. Note that the signal is not emitted when you call a non-slot - function such as insertLine(). - - \sa returnPressed() -*/ - -/* \fn void TQtMultiLineEdit::returnPressed() - - This signal is emitted when the user presses the return or enter - key. It is not emitted if isReadOnly() is TRUE. - - \sa textChanged() -*/ - -/* - \fn void TQtMultiLineEdit::undoAvailable (bool yes) - - This signal is emitted when the availability of undo changes. - If \a yes is TRUE, then undo() will work until - undoAvailable( FALSE ) is next emitted. -*/ - -/* - \fn void TQtMultiLineEdit::redoAvailable (bool yes) - - This signal is emitted when the availability of redo changes. - If \a yes is TRUE, then redo() will work until - redoAvailable( FALSE ) is next emitted. -*/ - -/* - \fn void TQtMultiLineEdit::copyAvailable (bool yes) - - This signal is emitted when the availability of cut/copy changes. - If \a yes is TRUE, then cut() and copy() will work until - copyAvailable( FALSE ) is next emitted. -*/ - - -/* - If \a on is FALSE, this multi line edit accepts text input. - Scrolling and cursor movements are accepted in any case. - - \sa isReadOnly() TQWidget::setEnabled() -*/ - -void TQtMultiLineEdit::setReadOnly( bool on ) -{ - if ( readOnly != on ) { - readOnly = on; -#ifndef TQT_NO_CURSOR - setCursor( on ? arrowCursor : ibeamCursor ); -#endif - } -} - -/* -*/ -int TQtMultiLineEdit::maxLineWidth() const -{ - return d->maxLineWidth; -} - -/* - Destroys the TQtMultiLineEdit -*/ - -TQtMultiLineEdit::~TQtMultiLineEdit() -{ - delete contents; - delete d; -} - -static TQPixmap *buffer = 0; - -static void cleanupMLBuffer() -{ - delete buffer; - buffer = 0; -} - -static TQPixmap *getCacheBuffer( TQSize sz ) -{ - if ( !buffer ) { - tqAddPostRoutine( cleanupMLBuffer ); - buffer = new TQPixmap; - } - - if ( buffer->width() < sz.width() || buffer->height() < sz.height() ) - buffer->resize( sz ); - return buffer; -} - -/* - Implements the basic drawing logic. Paints the line at row \a row - using painter \a painter. The \a col parameter is ignored. -*/ -void TQtMultiLineEdit::paintCell( TQPainter *painter, int row, int ) -{ - const TQColorGroup & g = colorGroup(); - TQFontMetrics fm( painter->font() ); - TQString s = stringShown(row); - if ( s.isNull() ) { - tqWarning( "TQtMultiLineEdit::paintCell: (%s) no text at line %d", - name( "unnamed" ), row ); - return; - } - TQRect updateR = cellUpdateRect(); - TQPixmap *buffer = getCacheBuffer( updateR.size() ); - ASSERT(buffer); - buffer->fill ( g.base() ); - - TQPainter p( buffer ); - p.setFont( painter->font() ); - p.translate( -updateR.left(), -updateR.top() ); - - p.setTabStops( tabStopDist(fm) ); - - int yPos = 0; - int markX1, markX2; // in x-coordinate pixels - markX1 = markX2 = 0; // avoid gcc warning - if ( markIsOn ) { - int markBeginX, markBeginY; - int markEndX, markEndY; - getMarkedRegion( &markBeginY, &markBeginX, &markEndY, &markEndX ); - if ( row >= markBeginY && row <= markEndY ) { - if ( row == markBeginY ) { - markX1 = markBeginX; - if ( row == markEndY ) // both marks on same row - markX2 = markEndX; - else - markX2 = s.length(); // mark till end of line - } else { - if ( row == markEndY ) { - markX1 = 0; - markX2 = markEndX; - } else { - markX1 = 0; // whole line is marked - markX2 = s.length(); // whole line is marked - } - } - } - } - p.setPen( g.text() ); - TQtMultiLineEditRow* r = contents->at( row ); - int wcell = cellWidth() - 2*d->lr_marg;// - d->marg_extra; - int wrow = r->w; - int x = d->lr_marg - p.fontMetrics().leftBearing(s[0]); - if ( d->align == TQt::AlignCenter || d->align == TQt::AlignHCenter ) - x += (wcell - wrow) / 2; - else if ( d->align == TQt::AlignRight ) - x += wcell - wrow; - p.drawText( x, yPos, cellWidth()-d->lr_marg-x, cellHeight(), - d->align == AlignLeft?ExpandTabs:0, s ); - if ( !r->newline && BREAK_WITHIN_WORDS ) - p.drawPixmap( x + wrow - d->lr_marg - d->marg_extra, yPos, d->arrow ); -#if 0 - if ( r->newline ) - p.drawLine( d->lr_marg, yPos+cellHeight()-2, cellWidth() - d->lr_marg, yPos+cellHeight()-2); -#endif - if ( markX1 != markX2 ) { - int sLength = s.length(); - int xpos1 = mapToView( markX1, row ); - int xpos2 = mapToView( markX2, row ); - int fillxpos1 = xpos1; - int fillxpos2 = xpos2; - if ( markX1 == 0 ) - fillxpos1 -= 2; - if ( markX2 == sLength ) - fillxpos2 += 3; - p.setClipping( TRUE ); - p.setClipRect( fillxpos1 - updateR.left(), 0, - fillxpos2 - fillxpos1, cellHeight(row) ); - p.fillRect( fillxpos1, 0, fillxpos2 - fillxpos1, cellHeight(row), - g.brush( TQColorGroup::Highlight ) ); - p.setPen( g.highlightedText() ); - p.drawText( x, yPos, cellWidth()-d->lr_marg-x, cellHeight(), - d->align == AlignLeft?ExpandTabs:0, s ); - p.setClipping( FALSE ); - } - - if ( row == cursorY && cursorOn && !readOnly ) { - int cursorPos = TQMIN( (int)s.length(), cursorX ); - int cXPos = TQMAX( mapToView( cursorPos, row ), 0 ); - int cYPos = 0; - if ( hasFocus() || d->dnd_forcecursor ) { - p.setPen( g.text() ); - /* styled? - p.drawLine( cXPos - 2, cYPos, - cXPos + 2, cYPos ); - */ - p.drawLine( cXPos, cYPos, - cXPos, cYPos + fm.height() - 2); - /* styled? - p.drawLine( cXPos - 2, cYPos + fm.height() - 2, - cXPos + 2, cYPos + fm.height() - 2); - */ - -#ifndef TQT_NO_TRANSFORMATIONS - // TODO: set it other times, eg. when scrollbar moves view - TQWMatrix wm = painter->worldMatrix(); - setMicroFocusHint( int(wm.dx()+cXPos), - int (wm.dy()+cYPos), - 1, fm.ascent() ); -#else - setMicroFocusHint( cXPos, - cYPos, - 1, fm.ascent() ); -#endif - } - } - p.end(); - painter->drawPixmap( updateR.left(), updateR.top(), *buffer, - 0, 0, updateR.width(), updateR.height() ); -} - - -/* - \overload - Returns the width in pixels of the string \a s. - NOTE: only appropriate for whole lines. -*/ - -int TQtMultiLineEdit::textWidth( const TQString &s ) -{ - int w = 0; - if ( !s.isNull() ) { - w = textWidthWithTabs( TQFontMetrics( font() ), s, 0, s.length(), - d->align ); - } - return w + 2 * d->lr_marg + d->marg_extra; -} - - -/* - Returns the width in pixels of the text at line \a line. -*/ - -int TQtMultiLineEdit::textWidth( int line ) -{ - if ( d->echomode == Password) { - TQString s = stringShown(line); - return textWidth( s ); - } - TQtMultiLineEditRow* r = contents->at(line); - return r?r->w:0; -} - -/* - Starts the cursor blinking. -*/ - -void TQtMultiLineEdit::focusInEvent( TQFocusEvent * ) -{ - stopAutoScroll(); - if ( !d->blinkTimer->isActive() ) - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); - cursorOn = TRUE; - updateCell( cursorY, 0, FALSE ); -} - - -/*\reimp -*/ -void TQtMultiLineEdit::leaveEvent( TQEvent * ) -{ -} - - -/*\reimp -*/ -void TQtMultiLineEdit::focusOutEvent( TQFocusEvent * ) -{ - stopAutoScroll(); - d->blinkTimer->stop(); - if ( cursorOn ) { - cursorOn = FALSE; - updateCell( cursorY, 0, FALSE ); - } -} - - -/* - \reimp - Present for binary compatibility only! -*/ - -void TQtMultiLineEdit::timerEvent( TQTimerEvent * ) -{ - // ############ Remove in 3.0!!!!!!!! -} - -#ifndef TQT_NO_DRAGANDDROP -void TQtMultiLineEdit::doDrag() -{ - if ( d->dnd_timer ) { - d->dnd_timer->stop(); - } - TQDragObject *drag_text = new TQTextDrag(markedText(), this); - if ( readOnly ) { - drag_text->dragCopy(); - } else { - if ( drag_text->drag() && TQDragObject::target() != this ) { - del(); - if ( textDirty && !d->isHandlingEvent ) - emit textChanged(); - } - } - d->dnd_primed = FALSE; -} -#endif - -/* - If there is marked text, sets \a line1, \a col1, \a line2 and \a col2 - to the start and end of the marked region and returns TRUE. Returns - FALSE if there is no marked text. - */ -bool TQtMultiLineEdit::getMarkedRegion( int *line1, int *col1, - int *line2, int *col2 ) const -{ - if ( !markIsOn || !line1 || !line2 || !col1 || !col2 ) - return FALSE; - if ( markAnchorY < markDragY || - markAnchorY == markDragY && markAnchorX < markDragX) { - *line1 = markAnchorY; - *col1 = markAnchorX; - *line2 = markDragY; - *col2 = markDragX; - if ( *line2 > numLines() - 1 ) { - *line2 = numLines() - 1; - *col2 = lineLength( *line2 ); - } - } else { - *line1 = markDragY; - *col1 = markDragX; - *line2 = markAnchorY; - *col2 = markAnchorX; - if ( *line2 > numLines() - 1 ) { - *line2 = numLines() - 1; - *col2 = lineLength( *line2 ); - } - } - return markIsOn; -} - - -/* - Returns TRUE if there is marked text. -*/ - -bool TQtMultiLineEdit::hasMarkedText() const -{ - return markIsOn; -} - - -/* - Returns a copy of the marked text. -*/ - -TQString TQtMultiLineEdit::markedText() const -{ - int markBeginX, markBeginY; - int markEndX, markEndY; - if ( !getMarkedRegion( &markBeginY, &markBeginX, &markEndY, &markEndX ) ) - return TQString(); - if ( markBeginY == markEndY ) { //just one line - TQString *s = getString( markBeginY ); - return s->mid( markBeginX, markEndX - markBeginX ); - } else { //multiline - TQString *firstS, *lastS; - firstS = getString( markBeginY ); - lastS = getString( markEndY ); - int i; - TQString tmp; - if ( firstS ) - tmp += firstS->mid(markBeginX); - if ( contents->at( markBeginY )->newline ) - tmp += '\n'; - - for( i = markBeginY + 1; i < markEndY ; i++ ) { - tmp += *getString(i); - if ( contents->at( i )->newline ) - tmp += '\n'; - } - - if ( lastS ) { - tmp += lastS->left(markEndX); - } else { - tmp.truncate(tmp.length()-1); - } - - return tmp; - } -} - - - -/* - Returns the text at line number \a line (possibly the empty string), - or a \link TQString::operator!() null string\endlink if \a line is invalid. -*/ - -TQString TQtMultiLineEdit::textLine( int line ) const -{ - TQString *s = getString(line); - if ( s ) { - if ( s->isNull() ) - return TQString::fromLatin1(""); - else - return *s; - } else - return TQString::null; -} - - -/* - Returns a copy of the whole text. If the multi line edit contains no - text, a - \link TQString::operator!() null string\endlink - is returned. -*/ - -TQString TQtMultiLineEdit::text() const -{ - TQString tmp; - for( int i = 0 ; i < (int)contents->count() ; i++ ) { - tmp += *getString(i); - if ( i+1 < (int)contents->count() && contents->at(i)->newline ) - tmp += '\n'; - } - return tmp; -} - - -/* - Selects all text without moving the cursor. -*/ - -void TQtMultiLineEdit::selectAll() -{ - markAnchorX = 0; - markAnchorY = 0; - markDragY = numLines() - 1; - markDragX = lineLength( markDragY ); - turnMark( markDragX != markAnchorX || markDragY != markAnchorY ); - if ( autoUpdate() ) - update(); -} - - - -/* - Deselects all text (i.e. removes marking) and leaves the cursor at the - current position. -*/ - -void TQtMultiLineEdit::deselect() -{ - turnMark( FALSE ); -} - - -/* - Sets the text to \a s, removing old text, if any. -*/ - -void TQtMultiLineEdit::setText( const TQString &s ) -{ - bool oldUndo = isUndoEnabled(); - setUndoEnabled( FALSE ); - bool oldAuto = autoUpdate(); - setAutoUpdate( FALSE ); - bool b = signalsBlocked(); - blockSignals( TRUE ); - clear(); - CLEAR_UNDO - blockSignals( b ); - insertLine( s, -1 ); - emit textChanged(); - setAutoUpdate(oldAuto); - if ( autoUpdate() ) - update(); - setUndoEnabled( oldUndo ); -} - - -/* - Appends \a s to the text. -*/ - -void TQtMultiLineEdit::append( const TQString &s ) -{ - bool oldUndo = isUndoEnabled(); - setUndoEnabled( FALSE ); - insertLine( s, -1 ); - setUndoEnabled( oldUndo ); - emit textChanged(); -} - -/* \reimp -Passes wheel events to the vertical scrollbar. -*/ -void TQtMultiLineEdit::wheelEvent( TQWheelEvent *e ){ - TQApplication::sendEvent( verticalScrollBar(), e); -} - - -/* - The key press event handler converts a key press in event \a e to - some line editor action. - - Here are the default key bindings when isReadOnly() is FALSE: - \list - \i <i> Left Arrow </i> Move the cursor one character leftwards - \i <i> Right Arrow </i> Move the cursor one character rightwards - \i <i> Up Arrow </i> Move the cursor one line upwards - \i <i> Down Arrow </i> Move the cursor one line downwards - \i <i> Page Up </i> Move the cursor one page upwards - \i <i> Page Down </i> Move the cursor one page downwards - \i <i> Backspace </i> Delete the character to the left of the cursor - \i <i> Home </i> Move the cursor to the beginning of the line - \i <i> End </i> Move the cursor to the end of the line - \i <i> Delete </i> Delete the character to the right of the cursor - \i <i> Shift - Left Arrow </i> Mark text one character leftwards - \i <i> Shift - Right Arrow </i> Mark text one character rightwards - \i <i> Control-A </i> Move the cursor to the beginning of the line - \i <i> Control-B </i> Move the cursor one character leftwards - \i <i> Control-C </i> Copy the marked text to the clipboard - \i <i> Control-D </i> Delete the character to the right of the cursor - \i <i> Control-E </i> Move the cursor to the end of the line - \i <i> Control-F </i> Move the cursor one character rightwards - \i <i> Control-H </i> Delete the character to the left of the cursor - \i <i> Control-K </i> Delete to end of line - \i <i> Control-N </i> Move the cursor one line downwards - \i <i> Control-P </i> Move the cursor one line upwards - \i <i> Control-V </i> Paste the clipboard text into line edit - \i <i> Control-X </i> Cut the marked text, copy to clipboard - \i <i> Control-Z </i> Undo the last operation - \i <i> Control-Y </i> Redo the last operation - \i <i> Control - Left Arrow </i> Move the cursor one word leftwards - \i <i> Control - Right Arrow </i> Move the cursor one word rightwards - \i <i> Control - Up Arrow </i> Move the cursor one word upwards - \i <i> Control - Down Arrow </i> Move the cursor one word downwards - \i <i> Control - Home Arrow </i> Move the cursor to the beginning of the text - \i <i> Control - End Arrow </i> Move the cursor to the end of the text - \endlist - In addition, the following key bindings are used on Windows: - \list - \i <i> Shift - Delete </i> Cut the marked text, copy to clipboard - \i <i> Shift - Insert </i> Paste the clipboard text into line edit - \i <i> Control - Insert </i> Copy the marked text to the clipboard - \endlist - All other keys with valid ASCII codes insert themselves into the line. - - Here are the default key bindings when isReadOnly() is TRUE: - \list - \i <i> Left Arrow </i> Scrolls the table rightwards - \i <i> Right Arrow </i> Scrolls the table rightwards - \i <i> Up Arrow </i> Scrolls the table one line downwards - \i <i> Down Arrow </i> Scrolls the table one line upwards - \i <i> Page Up </i> Scrolls the table one page downwards - \i <i> Page Down </i> Scrolls the table one page upwards - \i <i> Control-C </i> Copy the marked text to the clipboard - \endlist - -*/ - -void TQtMultiLineEdit::keyPressEvent( TQKeyEvent *e ) -{ - textDirty = FALSE; - d->isHandlingEvent = TRUE; - int unknown = 0; - if ( readOnly ) { - int pageSize = viewHeight() / cellHeight(); - - switch ( e->key() ) { - case Key_Left: - setXOffset( xOffset() - viewWidth()/10 ); - break; - case Key_Right: - setXOffset( xOffset() + viewWidth()/10 ); - break; - case Key_Up: - setTopCell( topCell() - 1 ); - break; - case Key_Down: - setTopCell( topCell() + 1 ); - break; - case Key_Home: - setCursorPosition(0,0, e->state() & ShiftButton ); - break; - case Key_End: - setCursorPosition( numLines()-1, lineLength( numLines()-1 ), - e->state() & ShiftButton ); - break; - case Key_Next: - setTopCell( topCell() + pageSize ); - break; - case Key_Prior: - setTopCell( TQMAX( topCell() - pageSize, 0 ) ); - break; -#ifndef TQT_NO_CLIPBOARD - case Key_C: - if ( echoMode() == Normal && (e->state()&ControlButton) ) - copy(); - else - unknown++; - break; - case Key_F16: // Copy key on Sun keyboards - if ( echoMode() == Normal ) - copy(); - else - unknown++; - break; -#endif - default: - unknown++; - } - if ( unknown ) - e->ignore(); - d->isHandlingEvent = FALSE; - return; - } - if ( e->text().length() && - e->key() != Key_Return && - e->key() != Key_Enter && - e->key() != Key_Delete && - e->key() != Key_Backspace && - (!e->ascii() || e->ascii()>=32) - ) { - insert( e->text() ); - //TQApplication::sendPostedEvents( this, TQEvent::Paint ); - if ( textDirty ) - emit textChanged(); - d->isHandlingEvent = FALSE; - return; - } - if ( e->state() & ControlButton ) { - switch ( e->key() ) { - case Key_A: - home( e->state() & ShiftButton ); - break; - case Key_B: - cursorLeft( e->state() & ShiftButton ); - break; -#ifndef TQT_NO_CLIPBOARD - case Key_C: - if ( echoMode() == Normal ) - copy(); - break; -#endif - case Key_D: - del(); - break; - case Key_E: - end( e->state() & ShiftButton ); - break; - case Key_Left: - cursorWordBackward( e->state() & ShiftButton ); - break; - case Key_Right: - cursorWordForward( e->state() & ShiftButton ); - break; - case Key_Up: - cursorUp( e->state() & ShiftButton ); - break; - case Key_Down: - cursorDown( e->state() & ShiftButton ); - break; - case Key_Home: - setCursorPosition(0,0, e->state() & ShiftButton ); - break; - case Key_End: - setCursorPosition( numLines()-1, lineLength( numLines()-1 ), - e->state() & ShiftButton ); - break; - case Key_F: - cursorRight( e->state() & ShiftButton ); - break; - case Key_H: - backspace(); - break; - case Key_K: - killLine(); - break; - case Key_N: - cursorDown( e->state() & ShiftButton ); - break; - case Key_P: - cursorUp( e->state() & ShiftButton ); - break; -#ifndef TQT_NO_CLIPBOARD - case Key_V: - paste(); - break; - case Key_X: - cut(); - break; -#endif - case Key_Z: - undo(); - break; - case Key_Y: - redo(); - break; -#if defined (_WS_WIN_) - case Key_Insert: - copy(); -#endif - default: - unknown++; - } - } else { - switch ( e->key() ) { - case Key_Left: - cursorLeft( e->state() & ShiftButton ); - break; - case Key_Right: - cursorRight( e->state() & ShiftButton ); - break; - case Key_Up: - cursorUp( e->state() & ShiftButton ); - break; - case Key_Down: - cursorDown( e->state() & ShiftButton ); - break; - case Key_Backspace: - backspace(); - break; - case Key_Home: - home( e->state() & ShiftButton ); - break; - case Key_End: - end( e->state() & ShiftButton ); - break; - case Key_Delete: -#if defined (_WS_WIN_) - if ( e->state() & ShiftButton ) { - cut(); - break; - } -#endif - del(); - break; - case Key_Next: - pageDown( e->state() & ShiftButton ); - break; - case Key_Prior: - pageUp( e->state() & ShiftButton ); - break; - case Key_Enter: - case Key_Return: - newLine(); - emit returnPressed(); - break; - case Key_Tab: - insert( e->text() ); - break; -#if defined (_WS_WIN_) - case Key_Insert: - if ( e->state() & ShiftButton ) - paste(); - else - unknown++; - break; -#endif - case Key_F14: // Undo key on Sun keyboards - undo(); - break; -#ifndef TQT_NO_CLIPBOARD - case Key_F16: // Copy key on Sun keyboards - if ( echoMode() == Normal ) - copy(); - break; - case Key_F18: // Paste key on Sun keyboards - paste(); - break; - case Key_F20: // Paste key on Sun keyboards - cut(); - break; -#endif - default: - unknown++; - } - } - if ( textDirty ) - emit textChanged(); - - if ( unknown ) // unknown key - e->ignore(); - - d->isHandlingEvent = FALSE; -} - - -/* - Moves the cursor one page down. If \a mark is TRUE, the text - is marked. -*/ - -void TQtMultiLineEdit::pageDown( bool mark ) -{ - bool oldAuto = autoUpdate(); - if ( mark ) - setAutoUpdate( FALSE ); - - if ( partiallyInvisible( cursorY ) ) - cursorY = topCell(); - int delta = cursorY - topCell(); - int pageSize = viewHeight() / cellHeight(); - int newTopCell = TQMIN( topCell() + pageSize, numLines() - 1 - pageSize ); - - if ( pageSize >= numLines() ) { // quick fix to handle small texts - newTopCell = topCell(); - } - if ( !curXPos ) - curXPos = mapToView( cursorX, cursorY ); - int oldY = cursorY; - - if ( mark && !hasMarkedText() ) { - markAnchorX = cursorX; - markAnchorY = cursorY; - } - if ( newTopCell != topCell() ) { - cursorY = newTopCell + delta; - cursorX = mapFromView( curXPos, cursorY ); - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - setTopCell( newTopCell ); - } else if ( cursorY != (int)contents->count() - 1) { // just move the cursor - cursorY = TQMIN( cursorY + pageSize, numLines() - 1); - cursorX = mapFromView( curXPos, cursorY ); - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - makeVisible(); - } - if ( oldAuto ) - if ( mark ) { - setAutoUpdate( TRUE ); - update(); - } else { - updateCell( oldY, 0, FALSE ); - } - if ( !mark ) - turnMark( FALSE ); -} - - -/* - Moves the cursor one page up. If \a mark is TRUE, the text - is marked. -*/ - -void TQtMultiLineEdit::pageUp( bool mark ) -{ - bool oldAuto = autoUpdate(); - if ( mark ) - setAutoUpdate( FALSE ); - if ( partiallyInvisible( cursorY ) ) - cursorY = topCell(); - int delta = cursorY - topCell(); - int pageSize = viewHeight() / cellHeight(); - bool partial = delta == pageSize && viewHeight() != pageSize * cellHeight(); - int newTopCell = TQMAX( topCell() - pageSize, 0 ); - if ( pageSize > numLines() ) { // quick fix to handle small texts - newTopCell = 0; - delta = 0; - } - if ( mark && !hasMarkedText() ) { - markAnchorX = cursorX; - markAnchorY = cursorY; - } - if ( !curXPos ) - curXPos = mapToView( cursorX, cursorY ); - int oldY = cursorY; - if ( newTopCell != topCell() ) { - cursorY = TQMIN( newTopCell + delta, numLines() - 1 ); - if ( partial ) - cursorY--; - cursorX = mapFromView( curXPos, cursorY ); - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - setTopCell( newTopCell ); - } else { // just move the cursor - cursorY = TQMAX( cursorY - pageSize, 0 ); - cursorX = mapFromView( curXPos, cursorY ); - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - } - if ( oldAuto ) - if ( mark ) { - setAutoUpdate( TRUE ); - update(); - } else { - updateCell( oldY, 0, FALSE ); - } - if ( !mark ) - turnMark( FALSE ); -} - -// THE CORE INSERTION FUNCTION -void TQtMultiLineEdit::insertAtAux( const TQString &txt, int line, int col, bool mark ) -{ - dummy = FALSE; - d->blinkTimer->stop(); - cursorOn = TRUE; - int oldw = contentsRect().width(); - - line = TQMAX( TQMIN( line, numLines() - 1), 0 ); - col = TQMAX( TQMIN( col, lineLength( line )), 0 ); - - TQString itxt = txt; - TQtMultiLineEditRow *row = contents->at( line ); - if ( d->maxlen >= 0 && length() + int(txt.length()) > d->maxlen ) - itxt.truncate( d->maxlen - length() ); - - row->s.insert( uint(col), itxt ); - - if ( mark ) { - markAnchorX = col; - markAnchorY = line; - } - if ( cursorX == col && cursorY == line ) { - cursorX += itxt.length(); - } - TQFontMetrics fm( font() ); - if ( !WORD_WRAP || ( col == 0 && itxt.contains('\n') == int(itxt.length())) ) - wrapLine( line, 0 ); - else if ( WORD_WRAP && itxt.find('\n')<0 && itxt.find('\t')<0 - && ( - ( DYNAMIC_WRAP && fm.width( itxt ) + row->w < contentsRect().width() - 2*d->lr_marg - d->marg_extra ) - || - ( FIXED_WIDTH_WRAP && ( d->wrapcol < 0 || fm.width( itxt ) + row->w < d->wrapcol ) ) - || - ( FIXED_COLUMN_WRAP && ( d->wrapcol < 0 || int(row->s.length()) < d->wrapcol ) ) - ) - && ( itxt.find(' ') < 0 || row->s.find(' ') >= 0 && row->s.find(' ') < col ) ){ - row->w = textWidth( row->s ); - setWidth( TQMAX( maxLineWidth(), row->w) ); - updateCell( line, 0, FALSE ); - } - else { - if ( line > 0 && !contents->at( line-1)->newline ) - rebreakParagraph( line-1 ); - else - rebreakParagraph( line ); - } - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - - setNumRowsAndTruncate(); - - textDirty = TRUE; - d->edited = TRUE; - if ( autoUpdate() ) { - makeVisible(); - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); - if ( DYNAMIC_WRAP && oldw != contentsRect().width() ) { - setAutoUpdate( FALSE ); - rebreakAll(); - setAutoUpdate( TRUE ); - update(); - } - } -} - - -/* - Inserts \a txt at line number \a line. If \a line is less than zero, - or larger than the number of rows, the new text is put at the end. - If \a txt contains newline characters, several lines are inserted. - - The cursor position is not changed. -*/ - -void TQtMultiLineEdit::insertLine( const TQString &txt, int line ) -{ - TQString s = txt; - int oldXPos = cursorX; - int oldYPos = cursorY; - if ( line < 0 || line >= int( contents->count() ) ) { - if ( !dummy ) - contents->append( new TQtMultiLineEditRow(TQString::fromLatin1(""), 0) ); - insertAt( s, numLines()-1, 0 ); - } else { - s.append('\n'); - insertAt( s, line, 0 ); - } - cursorX = oldXPos; - cursorY = oldYPos; -} - -/* - Deletes the line at line number \a line. If \a - line is less than zero, or larger than the number of lines, - no line is deleted. -*/ - -void TQtMultiLineEdit::removeLine( int line ) -{ - CLEAR_UNDO - if ( line >= numLines() ) - return; - if ( cursorY >= line && cursorY > 0 ) - cursorY--; - bool updt = autoUpdate() && rowIsVisible( line ); - TQtMultiLineEditRow* r = contents->at( line ); - ASSERT( r ); - bool recalc = r->w == maxLineWidth(); - contents->remove( line ); - if ( contents->count() == 0 ) { - int w = textWidth( TQString::fromLatin1("") ); - contents->append( new TQtMultiLineEditRow(TQString::fromLatin1(""), w) ); - setWidth( w ); - dummy = TRUE; - } - if ( setNumRowsAndTruncate() ) - recalc = updt = FALSE; - if ( recalc ) - updateCellWidth(); - makeVisible(); - if (updt) - update(); - textDirty = TRUE; - d->edited = TRUE; -} - -/* - Inserts \a s at the current cursor position. -*/ -void TQtMultiLineEdit::insert( const TQString& s ) -{ - insert( s, FALSE ); -} - -/* - Inserts \a c at the current cursor position. - (this function is provided for backward compatibility - - it simply calls insert()). -*/ -void TQtMultiLineEdit::insertChar( TQChar c ) -{ - insert(c); -} - -/* - \overload - Inserts string \a str at the current cursor position. If \a mark is - TRUE the string is marked. -*/ - -void TQtMultiLineEdit::insert( const TQString& str, bool mark ) -{ - dummy = FALSE; - bool wasMarkedText = hasMarkedText(); - if ( wasMarkedText ) - addUndoCmd( new TQBeginCommand ); - if ( wasMarkedText ) - del(); // ## Will flicker - TQString *s = getString( cursorY ); - if ( cursorX > (int)s->length() ) - cursorX = s->length(); - else if ( overWrite && !wasMarkedText && cursorX < (int)s->length() ) - del(); // ## Will flicker - insertAt(str, cursorY, cursorX, mark ); - makeVisible(); - - if ( wasMarkedText ) - addUndoCmd( new TQEndCommand() ); -} - -/* - Makes a line break at the current cursor position. -*/ - -void TQtMultiLineEdit::newLine() -{ - insert("\n"); -} - -/* - Deletes text from the current cursor position to the end of the line. -*/ - -void TQtMultiLineEdit::killLineAux() -{ - deselect(); // -sanders Don't let del() delete marked region - TQtMultiLineEditRow* r = contents->at( cursorY ); - if ( cursorX == (int)r->s.length() ) { - // if (r->newline) // -sanders Only del newlines! - del(); - return; - } else { - bool recalc = r->w == maxLineWidth(); - r->s.remove( cursorX, r->s.length() ); - r->w = textWidth( r->s ); - updateCell( cursorY, 0, FALSE ); - if ( recalc ) - updateCellWidth(); - rebreakParagraph( cursorY ); // -sanders - textDirty = TRUE; - d->edited = TRUE; - } - curXPos = 0; - makeVisible(); - turnMark( FALSE ); -} - - -/* - Moves the cursor one character to the left. If \a mark is TRUE, the text - is marked. If \a wrap is TRUE, the cursor moves to the end of the - previous line if it is placed at the beginning of the current line. - - \sa cursorRight() cursorUp() cursorDown() -*/ - -void TQtMultiLineEdit::cursorLeft( bool mark, bool wrap ) -{ - cursorLeft(mark,!mark,wrap); -} -void TQtMultiLineEdit::cursorLeft( bool mark, bool clear_mark, bool wrap ) -{ - if ( cursorX != 0 || cursorY != 0 && wrap ) { - if ( mark && !hasMarkedText() ) { - markAnchorX = cursorX; - markAnchorY = cursorY; - } - d->blinkTimer->stop(); - int ll = lineLength( cursorY ); - if ( cursorX > ll ) - cursorX = ll; - cursorOn = TRUE; - cursorX--; - if ( cursorX < 0 ) { - int oldY = cursorY; - if ( cursorY > 0 ) { - cursorY--; - cursorX = lineLength( cursorY ); - if ( cursorX > 1 && !isEndOfParagraph( cursorY ) ) - cursorX--; - } else { - cursorY = 0; //### ? - cursorX = 0; - } - updateCell( oldY, 0, FALSE ); - } - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); - updateCell( cursorY, 0, FALSE ); - } - curXPos = 0; - makeVisible(); - if ( clear_mark ) - turnMark( FALSE ); -} - -/* - Moves the cursor one character to the right. If \a mark is TRUE, the text - is marked. If \a wrap is TRUE, the cursor moves to the beginning of the next - line if it is placed at the end of the current line. - \sa cursorLeft() cursorUp() cursorDown() -*/ - -void TQtMultiLineEdit::cursorRight( bool mark, bool wrap ) -{ - cursorRight(mark,!mark,wrap); -} -void TQtMultiLineEdit::cursorRight( bool mark, bool clear_mark, bool wrap ) -{ - int strl = lineLength( cursorY ); - if ( strl > 1 && !isEndOfParagraph( cursorY ) ) - strl--; - if ( cursorX < strl || cursorY < (int)contents->count() - 1 && wrap ) { - if ( mark && !hasMarkedText() ) { - markAnchorX = cursorX; - markAnchorY = cursorY; - } - d->blinkTimer->stop(); - cursorOn = TRUE; - cursorX++; - if ( cursorX > strl ) { - int oldY = cursorY; - if ( cursorY < (int) contents->count() - 1 ) { - cursorY++; - cursorX = 0; - } else { - cursorX = lineLength( cursorY ); - } - updateCell( oldY, 0, FALSE ); - } - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - updateCell( cursorY, 0, FALSE ); - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); - } - curXPos = 0; - makeVisible(); - if ( clear_mark ) - turnMark( FALSE ); -} - -/* - Moves the cursor up one line. If \a mark is TRUE, the text - is marked. - \sa cursorDown() cursorLeft() cursorRight() -*/ - -void TQtMultiLineEdit::cursorUp( bool mark ) -{ - cursorUp(mark,!mark); -} -void TQtMultiLineEdit::cursorUp( bool mark, bool clear_mark ) -{ - if ( cursorY != 0 ) { - if ( mark && !hasMarkedText() ) { - markAnchorX = cursorX; - markAnchorY = cursorY; - } - if ( !curXPos ) - curXPos = mapToView( cursorX, cursorY ); - int oldY = cursorY; - d->blinkTimer->stop(); - cursorOn = TRUE; - cursorY--; - if ( cursorY < 0 ) { - cursorY = 0; - } - cursorX = mapFromView( curXPos, cursorY ); - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - updateCell( oldY, 0, FALSE ); - updateCell( cursorY, 0, FALSE ); - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); - } - makeVisible(); - if ( clear_mark ) - turnMark( FALSE ); -} - -/* - Moves the cursor one line down. If \a mark is TRUE, the text - is marked. - \sa cursorUp() cursorLeft() cursorRight() -*/ - -void TQtMultiLineEdit::cursorDown( bool mark ) -{ - cursorDown(mark,!mark); -} -void TQtMultiLineEdit::cursorDown( bool mark, bool clear_mark ) -{ - int lastLin = contents->count() - 1; - if ( cursorY != lastLin ) { - if ( mark && !hasMarkedText() ) { - markAnchorX = cursorX; - markAnchorY = cursorY; - } - if ( !curXPos ) - curXPos = mapToView( cursorX, cursorY ); - int oldY = cursorY; - d->blinkTimer->stop(); - cursorOn = TRUE; - cursorY++; - if ( cursorY > lastLin ) { - cursorY = lastLin; - } - cursorX = mapFromView( curXPos, cursorY ); - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - updateCell( oldY, 0, FALSE ); - updateCell( cursorY, 0, FALSE ); - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); - } - makeVisible(); - if ( clear_mark ) - turnMark( FALSE ); -} - -/* - Turns off marked text -*/ -void TQtMultiLineEdit::turnMark( bool on ) -{ - if ( on != markIsOn ) { - markIsOn = on; - if ( echoMode() == Normal ) - emit copyAvailable( on ); - update(); - } -} - - - - -/* - Deletes the character on the left side of the text cursor and moves - the cursor one position to the left. If a text has been marked by - the user (e.g. by clicking and dragging) the cursor is put at the - beginning of the marked text and the marked text is removed. - \sa del() -*/ - -void TQtMultiLineEdit::backspace() -{ - if ( hasMarkedText() ) { - del(); - } else { - if ( !atBeginning() ) { - cursorLeft( FALSE ); - del(); - } - } - makeVisible(); -} - -void TQtMultiLineEdit::delAux() -{ - int markBeginX, markBeginY; - int markEndX, markEndY; - TQRect oldContents = contentsRect(); - if ( getMarkedRegion( &markBeginY, &markBeginX, &markEndY, &markEndX ) ) { - turnMark( FALSE ); - textDirty = TRUE; - d->edited = TRUE; - if ( markBeginY == markEndY ) { //just one line - TQtMultiLineEditRow *r = contents->at( markBeginY ); - ASSERT(r); - bool recalc = r->w == maxLineWidth(); - r->s.remove( markBeginX, markEndX - markBeginX ); - r->w = textWidth( r->s ); - cursorX = markBeginX; - cursorY = markBeginY; - - if (autoUpdate() ) - updateCell( cursorY, 0, FALSE ); - if ( recalc ) - updateCellWidth(); - } else { //multiline - bool oldAuto = autoUpdate(); - setAutoUpdate( FALSE ); - ASSERT( markBeginY >= 0); - ASSERT( markEndY < (int)contents->count() ); - - TQtMultiLineEditRow *firstR, *lastR; - firstR = contents->at( markBeginY ); - lastR = contents->at( markEndY ); - ASSERT( firstR != lastR ); - firstR->s.remove( markBeginX, firstR->s.length() - markBeginX ); - lastR->s.remove( 0, markEndX ); - firstR->s.append( lastR->s ); // lastS will be removed in loop below - firstR->newline = lastR->newline; // Don't forget this -sanders - firstR->w = textWidth( firstR->s ); - - for( int i = markBeginY + 1 ; i <= markEndY ; i++ ) - contents->remove( markBeginY + 1 ); - - if ( contents->isEmpty() ) - insertLine( TQString::fromLatin1(""), -1 ); - - cursorX = markBeginX; - cursorY = markBeginY; - curXPos = 0; - - setNumRowsAndTruncate(); - updateCellWidth(); - setAutoUpdate( oldAuto ); - if ( autoUpdate() ) - update(); - } - markAnchorY = markDragY = cursorY; - markAnchorX = markDragX = cursorX; - } else { - if ( !atEnd() ) { - textDirty = TRUE; - d->edited = TRUE; - TQtMultiLineEditRow *r = contents->at( cursorY ); - if ( cursorX == (int) r->s.length() ) { // remove newline - TQtMultiLineEditRow* other = contents->at( cursorY + 1 ); - if ( ! r->newline && cursorX ) - r->s.truncate( r->s.length()-1 ); - - bool needBreak = !r->s.isEmpty(); - r->s += other->s; - r->newline = other->newline; - contents->remove( cursorY + 1 ); - if ( needBreak ) - rebreakParagraph( cursorY, 1 ); - else - wrapLine( cursorY, 1 ); - } else { - bool recalc = r->w == maxLineWidth(); - r->s.remove( cursorX, 1 ); - rebreakParagraph( cursorY ); - if ( recalc ) - updateCellWidth(); - } - } - } - if ( DYNAMIC_WRAP && oldContents != contentsRect() ) { - if ( oldContents.width() != contentsRect().width() ) { - bool oldAuto = autoUpdate(); - setAutoUpdate( FALSE ); - rebreakAll(); - setAutoUpdate( oldAuto ); - } - if ( autoUpdate() ) - update(); - } - curXPos = 0; - makeVisible(); -} - -/* - Moves the text cursor to the left end of the line. If \a mark is - TRUE, text is marked towards the first position. If it is FALSE and - the cursor is moved, all marked text is unmarked. - - \sa end() -*/ - -void TQtMultiLineEdit::home( bool mark ) -{ - if ( cursorX != 0 ) { - if ( mark && !hasMarkedText() ) { - markAnchorX = cursorX; - markAnchorY = cursorY; - } - d->blinkTimer->stop(); - cursorX = 0; - cursorOn = TRUE; - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - updateCell( cursorY, 0, FALSE ); - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); - } - curXPos = 0; - if ( !mark ) - turnMark( FALSE ); - makeVisible(); -} - -/* - Moves the text cursor to the right end of the line. If \a mark is TRUE - text is marked towards the last position. If it is FALSE and the - cursor is moved, all marked text is unmarked. - - \sa home() -*/ - -void TQtMultiLineEdit::end( bool mark ) -{ - int tlen = lineLength( cursorY ); - if ( cursorX != tlen ) { - if ( mark && !hasMarkedText() ) { - markAnchorX = cursorX; - markAnchorY = cursorY; - } - d->blinkTimer->stop(); - cursorX = tlen; - cursorOn = TRUE; - if ( mark ) - newMark( cursorX, cursorY, FALSE ); - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); - updateCell( cursorY, 0, FALSE ); - } - curXPos = 0; - makeVisible(); - if ( !mark ) - turnMark( FALSE ); -} - -/*\reimp -*/ -void TQtMultiLineEdit::mousePressEvent( TQMouseEvent *e ) -{ - stopAutoScroll(); - d->dnd_startpos = e->pos(); - - if ( e->button() == RightButton ) { - TQPopupMenu *popup = new TQPopupMenu( this ); - int id[ (int)IdCount ]; - id[ IdUndo ] = popup->insertItem( tr( "Undo" ) ); - id[ IdRedo ] = popup->insertItem( tr( "Redo" ) ); - popup->insertSeparator(); -#ifndef TQT_NO_CLIPBOARD - id[ IdCut ] = popup->insertItem( tr( "Cut" ) ); - id[ IdCopy ] = popup->insertItem( tr( "Copy" ) ); - id[ IdPaste ] = popup->insertItem( tr( "Paste" ) ); -#ifndef TQT_NO_MIMECLIPBOARD - id[ IdPasteSpecial ] = popup->insertItem( tr( "Paste special..." ) ); -#endif -#endif - id[ IdClear ] = popup->insertItem( tr( "Clear" ) ); - popup->insertSeparator(); - id[ IdSelectAll ] = popup->insertItem( tr( "Select All" ) ); - popup->setItemEnabled( id[ IdUndo ], - !this->d->undoList.isEmpty() ); - popup->setItemEnabled( id[ IdRedo ], - !this->d->redoList.isEmpty() ); -#ifndef TQT_NO_CLIPBOARD - popup->setItemEnabled( id[ IdCut ], - !isReadOnly() && hasMarkedText() ); - popup->setItemEnabled( id[ IdCopy ], hasMarkedText() ); - popup->setItemEnabled( id[ IdPaste ], - !isReadOnly() && (bool)TQApplication::clipboard()->text().length() ); -#ifndef TQT_NO_MIMECLIPBOARD - // Any non-plain types? - TQMimeSource* ms = TQApplication::clipboard()->data(); - bool ps = FALSE; - if ( ms ) { - if ( !isReadOnly() ) { - const char* fmt; - for (int i=0; !ps && (fmt=ms->format(i)); i++) { - ps = tqstrnicmp(fmt,"text/",5)==0 - && tqstrnicmp(fmt+5,"plain",5)!=0; - } - } - } - popup->setItemEnabled( id[ IdPasteSpecial ], ps ); -#endif -#endif - popup->setItemEnabled( id[ IdClear ], - !isReadOnly() && (bool)text().length() ); - int allSelected = markIsOn && markAnchorX == 0 && markAnchorY == 0 && - markDragY == numLines() - 1 && markDragX == lineLength( markDragY ); - popup->setItemEnabled( id[ IdSelectAll ], - (bool)text().length() && !allSelected ); - - int r = popup->exec( e->globalPos() ); - delete popup; - - if ( r == id[ IdUndo ] ) - undo(); - else if ( r == id[ IdRedo ] ) - redo(); -#ifndef TQT_NO_CLIPBOARD - else if ( r == id[ IdCut ] ) - cut(); - else if ( r == id[ IdCopy ] ) - copy(); - else if ( r == id[ IdPaste ] ) - paste(); -# ifndef TQT_NO_MIMECLIPBOARD - else if ( r == id[ IdPasteSpecial ] ) - pasteSpecial(TQCursor::pos()); -# endif -#endif - else if ( r == id[ IdClear ] ) - clear(); - else if ( r == id[ IdSelectAll ] ) - selectAll(); - return; - } - - if ( e->button() != MidButton && e->button() != LeftButton) - return; - - int newX, newY; - pixelPosToCursorPos( e->pos(), &newX, &newY ); - - if ( e->state() & ShiftButton ) { - wordMark = FALSE; - dragMarking = TRUE; - setCursorPosition( newY, newX, TRUE); - return; - } - -#ifndef TQT_NO_DRAGANDDROP - if ( - inMark(newX, newY) // Click on highlighted text - && echoMode() == Normal // No DnD of passwords, etc. - && e->pos().y() < totalHeight() // Click past the end is not dragging - ) - { - // The user might be trying to drag - d->dnd_primed = TRUE; - d->dnd_timer->start( TQApplication::startDragTime(), FALSE ); - } else -#endif - { - wordMark = FALSE; - dragMarking = TRUE; - setCursorPixelPosition(e->pos()); - } -} - -void TQtMultiLineEdit::pixelPosToCursorPos(TQPoint p, int* x, int* y) const -{ - *y = findRow( p.y() ); - if ( *y < 0 ) { - if ( p.y() < lineWidth() ) { - *y = topCell(); - } else { - *y = lastRowVisible(); - p.setX(cellWidth()); - } - } - *y = TQMIN( (int)contents->count() - 1, *y ); - TQFontMetrics fm( font() ); - *x = xPosToCursorPos( stringShown( *y ), fm, - p.x() - d->lr_marg + xOffset(), - cellWidth() - 2 * d->lr_marg - d->marg_extra, - d->align ); - TQtMultiLineEditRow* r = contents->at( *y ); - if (r && !r->newline && ((unsigned int)*x == r->s.length()) && (*x > 0)) - --*x; -} - -void TQtMultiLineEdit::setCursorPixelPosition(TQPoint p, bool clear_mark) -{ - int newY; - pixelPosToCursorPos( p, &cursorX, &newY ); - curXPos = 0; - if ( clear_mark ) { - markAnchorX = cursorX; - markAnchorY = newY; - bool markWasOn = markIsOn; - turnMark( FALSE ); - if ( markWasOn ) { - cursorY = newY; - update(); - d->isHandlingEvent = FALSE; - return; - } - } - if ( cursorY != newY ) { - int oldY = cursorY; - cursorY = newY; - updateCell( oldY, 0, FALSE ); - } - updateCell( cursorY, 0, FALSE ); // ### -} - -void TQtMultiLineEdit::startAutoScroll() -{ - if ( !dragScrolling ) { - d->scrollTime = initialScrollTime; - d->scrollAccel = initialScrollAccel; - d->scrollTimer->start( d->scrollTime, FALSE ); - dragScrolling = TRUE; - } -} - -void TQtMultiLineEdit::stopAutoScroll() -{ - if ( dragScrolling ) { - d->scrollTimer->stop(); - dragScrolling = FALSE; - } -} - -/*\reimp -*/ -void TQtMultiLineEdit::mouseMoveEvent( TQMouseEvent *e ) -{ -#ifndef TQT_NO_DRAGANDDROP - d->dnd_timer->stop(); - if ( d->dnd_primed && - ( d->dnd_startpos - e->pos() ).manhattanLength() > TQApplication::startDragDistance() ) { - doDrag(); - return; - } -#endif - if ( !dragMarking ) - return; - if ( rect().contains( e->pos() ) ) { - stopAutoScroll(); - } else if ( !dragScrolling ) { - startAutoScroll(); - } - - int newX, newY; - pixelPosToCursorPos(e->pos(), &newX, &newY); - - if ( wordMark ) { - extendSelectionWord( newX, newY); - } - - if ( markDragX == newX && markDragY == newY ) - return; - int oldY = markDragY; - newMark( newX, newY, FALSE ); - for ( int i = TQMIN(oldY,newY); i <= TQMAX(oldY,newY); i++ ) - updateCell( i, 0, FALSE ); -} - -void TQtMultiLineEdit::extendSelectionWord( int &newX, int&newY) -{ - TQString s = stringShown( newY ); - int lim = s.length(); - if ( newX >= 0 && newX < lim ) { - int i = newX; - int startclass = charClass(s.at(i)); - if ( markAnchorY < markDragY || - ( markAnchorY == markDragY && markAnchorX < markDragX ) ) { - // going right - while ( i < lim && charClass(s.at(i)) == startclass ) - i++; - } else { - // going left - while ( i >= 0 && charClass(s.at(i)) == startclass ) - i--; - i++; - } - newX = i; - } -} - - - - -/*\reimp -*/ -void TQtMultiLineEdit::mouseReleaseEvent( TQMouseEvent *e ) -{ - stopAutoScroll(); -#ifndef TQT_NO_DRAGANDDROP - if ( d->dnd_timer->isActive() ) { - d->dnd_timer->stop(); - d->dnd_primed = FALSE; - setCursorPixelPosition(e->pos()); - } -#endif - wordMark = FALSE; - dragMarking = FALSE; - textDirty = FALSE; - d->isHandlingEvent = TRUE; - if ( markAnchorY == markDragY && markAnchorX == markDragX ) - turnMark( FALSE ); - -#ifndef TQT_NO_CLIPBOARD -#if defined(_WS_X11_) - else if ( echoMode() == Normal ) - copy(); -#endif - - if ( e->button() == MidButton && !readOnly ) { -#if defined(_WS_X11_) - paste(); // Will repaint the cursor line. -#else -#ifndef TQT_NO_COMPAT - if ( style().styleHint(TQStyle::SH_GUIStyle) == TQt::MotifStyle ) - paste(); -#endif -#endif - } -#endif - - d->isHandlingEvent = FALSE; - - if ( !readOnly && textDirty ) - emit textChanged(); -} - - -/*\reimp -*/ -void TQtMultiLineEdit::mouseDoubleClickEvent( TQMouseEvent *m ) -{ - if ( m->button() == LeftButton ) { - if ( m->state() & ShiftButton ) { - int newX = cursorX; - int newY = cursorY; - extendSelectionWord( newX, newY); - newMark( newX, newY, FALSE ); - } else { - markWord( cursorX, cursorY ); - } - dragMarking = TRUE; - wordMark = TRUE; - updateCell( cursorY, 0, FALSE ); - - } -} - -#ifndef TQT_NO_DRAGANDDROP - -/* - \reimp -*/ - -void TQtMultiLineEdit::dragEnterEvent( TQDragEnterEvent * ) -{ - cursorOn = TRUE; - updateCell( cursorY, 0, FALSE ); -} - -/*\reimp -*/ -void TQtMultiLineEdit::dragMoveEvent( TQDragMoveEvent* event ) -{ - if ( readOnly ) return; - event->accept( TQTextDrag::canDecode(event) ); - d->dnd_forcecursor = TRUE; - setCursorPixelPosition(event->pos(), FALSE); - d->dnd_forcecursor = FALSE; - TQRect inside_margin(scroll_margin, scroll_margin, - width()-scroll_margin*2, height()-scroll_margin*2); - if ( !inside_margin.contains(event->pos()) ) { - startAutoScroll(); - } - if ( event->source() == this && event->action() == TQDropEvent::Move ) - event->acceptAction(); -} - -/*\reimp -*/ -void TQtMultiLineEdit::dragLeaveEvent( TQDragLeaveEvent* ) -{ - if ( cursorOn ) { - cursorOn = FALSE; - updateCell( cursorY, 0, FALSE ); - } - stopAutoScroll(); -} - -/*\reimp -*/ -void TQtMultiLineEdit::dropEvent( TQDropEvent* event ) -{ - if ( readOnly ) return; - TQString text; - TQCString fmt = pickSpecial(event,FALSE,event->pos()); - if ( TQTextDrag::decode(event, text, fmt) ) { - int i = -1; - while ( ( i = text.find( '\r' ) ) != -1 ) - text.replace( i,1,"" ); - if ( event->source() == this && event->action() == TQDropEvent::Move ) { - event->acceptAction(); - // Careful not to tread on my own feet - int newX, newY; - pixelPosToCursorPos( event->pos(), &newX, &newY ); - if ( afterMark( newX, newY ) ) { - // The tricky case - int x1, y1, x2, y2; - getMarkedRegion( &y1, &x1, &y2, &x2 ); - if ( newY == y2 ) { - newY = y1; - newX = x1 + newX - x2; - } else { - newY -= y2 - y1; - } - addUndoCmd( new TQBeginCommand ); - del(); - setCursorPosition(newY, newX); - insert(text, TRUE); - addUndoCmd( new TQEndCommand ); - } else if ( beforeMark( newX, newY ) ) { - // Easy - addUndoCmd( new TQBeginCommand ); - del(); - setCursorPosition(newY, newX); - insert(text, TRUE); - addUndoCmd( new TQEndCommand ); - } else { - // Do nothing. - } - } else { - setCursorPixelPosition(event->pos()); - insert(text, TRUE); - } - update(); - emit textChanged(); - } -} - -#endif // TQT_NO_DRAGANDDROP - - -/* - Returns TRUE if line \a line is invisible or partially invisible. -*/ - -bool TQtMultiLineEdit::partiallyInvisible( int line ) -{ - int y; - if ( !rowYPos( line, &y ) ) - return TRUE; - if ( y < 0 ) - return TRUE; - else if ( y + cellHeight() - 2 > viewHeight() ) - return TRUE; - - return FALSE; -} - -/* - Scrolls such that the cursor is visible -*/ - -void TQtMultiLineEdit::makeVisible() -{ - if ( !autoUpdate() ) - return; - - if ( partiallyInvisible( cursorY ) ) { - if ( cursorY >= lastRowVisible() ) - setBottomCell( cursorY ); - else - setTopCell( cursorY ); - } - int xPos = mapToView( cursorX, cursorY ); - if ( xPos < xOffset() ) { - int of = xPos - 10; //### - setXOffset( of ); - } else if ( xPos > xOffset() + viewWidth() ) { - int of = xPos - viewWidth() + 10; //### - setXOffset( of ); - } -} - -/* - Computes the character position in line \a line which corresponds - to pixel \a xPos -*/ - -int TQtMultiLineEdit::mapFromView( int xPos, int line ) -{ - TQString s = stringShown( line ); - if ( !s ) - return 0; - TQFontMetrics fm( font() ); - int index = xPosToCursorPos( s, fm, - xPos - d->lr_marg, - cellWidth() - 2 * d->lr_marg - d->marg_extra, - d->align ); - TQtMultiLineEditRow* r = contents->at( line ); - if (r && !r->newline && ((unsigned int)index == r->s.length()) && (index > 0)) - --index; - return index; -} - -/* - Computes the pixel position in line \a line which corresponds to - character position \a xIndex -*/ - -int TQtMultiLineEdit::mapToView( int xIndex, int line ) -{ - TQString s = stringShown( line ); - xIndex = TQMIN( (int)s.length(), xIndex ); - TQFontMetrics fm( font() ); - int wcell = cellWidth() - 2 * d->lr_marg;// - d->marg_extra; - int wrow = contents->at( line )->w; - int w = textWidthWithTabs( fm, s, 0, xIndex, d->align ) - 1; - if ( d->align == TQt::AlignCenter || d->align == TQt::AlignHCenter ) - w += (wcell - wrow) / 2; - else if ( d->align == TQt::AlignRight ) - w += wcell - wrow; - return d->lr_marg + w; -} - -/* - Traverses the list and finds an item with the maximum width, and - updates the internal list box structures accordingly. -*/ - -void TQtMultiLineEdit::updateCellWidth() -{ - TQtMultiLineEditRow* r = contents->first(); - int maxW = 0; - int w; - switch ( d->echomode ) { - case Normal: - while ( r ) { - w = r->w; - if ( w > maxW ) - maxW = w; - r = contents->next(); - } - break; - case Password: { - uint l = 0; - while ( r ) { - l = TQMAX(l, r->s.length() ); - r = contents->next(); - } - TQString t; - t.fill(TQChar('*'), l); - maxW = textWidth(t); - } - break; - case NoEcho: - maxW = textWidth(TQString::fromLatin1("")); - } - setWidth( maxW ); -} - - -/* - Sets the bottommost visible line to \a line. -*/ - -void TQtMultiLineEdit::setBottomCell( int line ) -{ - int rowY = cellHeight() * line; - int newYPos = rowY + cellHeight() - viewHeight(); - setYOffset( TQMAX( newYPos, 0 ) ); -} - -#ifndef TQT_NO_CLIPBOARD - -/* - Copies text in MIME subtype \a subtype from the clipboard onto the current - cursor position. - Any marked text is first deleted. -*/ -void TQtMultiLineEdit::pasteSubType(const TQCString& subtype) -{ - TQCString st = subtype; - addUndoCmd( new TQBeginCommand ); - - if ( hasMarkedText() ) - del(); - TQString t = TQApplication::clipboard()->text(st); - if ( !t.isEmpty() ) { - if ( hasMarkedText() ) - turnMark( FALSE ); - -#if defined(_OS_WIN32_) - // Need to convert CRLF to NL - t.replace( "\r\n", "\n" ); -#endif - - for (int i=0; (uint)i<t.length(); i++) { - if ( t[i] < ' ' && t[i] != '\n' && t[i] != '\t' ) - t[i] = ' '; - } - insertAt( t, cursorY, cursorX ); - turnMark( FALSE ); - curXPos = 0; - makeVisible(); - } - if ( textDirty && !d->isHandlingEvent ) - emit textChanged(); - - addUndoCmd( new TQEndCommand ); -} - -/* - Copies plain text from the clipboard onto the current cursor position. - Any marked text is first deleted. -*/ -void TQtMultiLineEdit::paste() -{ - pasteSubType("plain"); -} - -#ifndef TQT_NO_MIMECLIPBOARD -/* - Prompts the user for a type from a list of text types available, - Then copies text from the clipboard onto the current cursor position. - Any marked text is first deleted. -*/ -void TQtMultiLineEdit::pasteSpecial(const TQPoint& pt) -{ - TQCString st = pickSpecial(TQApplication::clipboard()->data(),TRUE,pt); - if ( !st.isEmpty() ) - pasteSubType(st); -} -#endif -#ifndef TQT_NO_MIME -TQCString TQtMultiLineEdit::pickSpecial(TQMimeSource* ms, bool always_ask, const TQPoint& pt) -{ - if ( ms ) { - TQPopupMenu popup(this); - TQString fmt; - int n=0; - TQDict<void> done; - for (int i=0; !(fmt=ms->format(i)).isNull(); i++) { - int semi=fmt.find(";"); - if ( semi >= 0 ) - fmt = fmt.left(semi); - if ( fmt.left(5) == "text/" ) { - fmt = fmt.mid(5); - if ( !done.find(fmt) ) { - done.insert(fmt,(void*)1); - popup.insertItem(fmt,i); - n++; - } - } - } - if ( n ) { - int i = n==1 && !always_ask ? popup.idAt(0) : popup.exec(pt); - if ( i >= 0 ) - return popup.text(i).latin1(); - } - } - return TQCString(); -} -#endif // TQT_NO_MIME -#endif // TQT_NO_CLIPBOARD - - -/* - Removes all text. -*/ - -void TQtMultiLineEdit::clear() -{ - addUndoCmd( new TQDelTextCmd( 0, text() ) ); - setEdited( TRUE ); - contents->clear(); - cursorX = cursorY = 0; - int w = textWidth( TQString::fromLatin1("") ); - contents->append( new TQtMultiLineEditRow(TQString::fromLatin1(""), w) ); - setNumRowsAndTruncate(); - setWidth( w ); - dummy = TRUE; - turnMark( FALSE ); - if ( autoUpdate() ) - update(); - if ( !d->isHandlingEvent ) //# && not already empty - emit textChanged(); - update(); -} - - -/*\reimp -*/ - -void TQtMultiLineEdit::setFont( const TQFont &font ) -{ - TQWidget::setFont( font ); - d->clearChartable(); - TQFontMetrics fm( font ); - setCellHeight( fm.lineSpacing() ); - for ( TQtMultiLineEditRow* r = contents->first(); r; r = contents->next() ) - r->w = textWidth( r->s ); - rebreakAll(); - updateCellWidth(); -} - -/* - Sets a new marked text limit, does not repaint the widget. -*/ - -void TQtMultiLineEdit::newMark( int posx, int posy, bool /*copy*/ ) -{ - if ( markIsOn && markDragX == posx && markDragY == posy && - cursorX == posx && cursorY == posy ) - return; - markDragX = posx; - markDragY = posy; - cursorX = posx; - cursorY = posy; - turnMark( markDragX != markAnchorX || markDragY != markAnchorY ); -} - -bool TQtMultiLineEdit::beforeMark( int posx, int posy ) const -{ - int x1, y1, x2, y2; - if ( !getMarkedRegion( &y1, &x1, &y2, &x2 ) ) - return FALSE; - return - (y1 > posy || y1 == posy && x1 > posx) - && (y2 > posy || y2 == posy && x2 > posx); -} - -bool TQtMultiLineEdit::afterMark( int posx, int posy ) const -{ - int x1, y1, x2, y2; - if ( !getMarkedRegion( &y1, &x1, &y2, &x2 ) ) - return FALSE; - return - (y1 < posy || y1 == posy && x1 < posx) - && (y2 < posy || y2 == posy && x2 < posx); -} - -bool TQtMultiLineEdit::inMark( int posx, int posy ) const -{ - int x1, y1, x2, y2; - if ( !getMarkedRegion( &y1, &x1, &y2, &x2 ) ) - return FALSE; - return - (y1 < posy || y1 == posy && x1 <= posx) - && (y2 > posy || y2 == posy && x2 >= posx); -} - -/* - Marks the word at character position \a posx, \a posy. - */ -void TQtMultiLineEdit::markWord( int posx, int posy ) -{ - TQString& s = contents->at( posy )->s; - - int i = posx - 1; - while ( i >= 0 && s[i].isPrint() && !s[i].isSpace() ) - i--; - i++; - markAnchorY = posy; - markAnchorX = i; - - while ( s[i].isPrint() && !s[i].isSpace() ) - i++; - markDragX = i; - markDragY = posy; - turnMark( markDragX != markAnchorX || markDragY != markAnchorY ); - -#ifndef TQT_NO_CLIPBOARD -#if defined(_WS_X11_) - if ( echoMode() == Normal ) - copy(); -#endif -#endif -} - -/* - This may become a protected virtual member in a future TQt. - This implementation is an example of a useful classification - that aids selection of common units like filenames and URLs. -*/ -int TQtMultiLineEdit::charClass( TQChar ch ) -{ - if ( !ch.isPrint() || ch.isSpace() ) return 1; - else if ( ch.isLetter() || ch=='-' || ch=='+' || ch==':' - || ch=='.' || ch=='/' || ch=='\\' - || ch=='@' || ch=='$' || ch=='~' ) return 2; - else return 3; -} - -#ifndef TQT_NO_CLIPBOARD -/* - Copies the marked text to the clipboard. Will copy only - if echoMode() is Normal. -*/ - -void TQtMultiLineEdit::copy() const -{ - TQString t = markedText(); - if ( !t.isEmpty() && echoMode() == Normal ) { -#if defined(_WS_X11_) - disconnect( TQApplication::clipboard(), SIGNAL(dataChanged()), this, 0); -#endif -#if defined(_OS_WIN32_) - // Need to convert NL to CRLF - t.replace( "\n", "\r\n" ); -#endif - TQApplication::clipboard()->setText( t ); -#if defined(_WS_X11_) - connect( TQApplication::clipboard(), SIGNAL(dataChanged()), - this, SLOT(clipboardChanged()) ); -#endif - } -} - -/* \obsolete - - Backward compatibility. -*/ -void TQtMultiLineEdit::copyText() const -{ - copy(); -} - -/* - Copies the selected text to the clipboard and deletes the selected text. -*/ - -void TQtMultiLineEdit::cut() -{ - if ( hasMarkedText() ) { - if ( echoMode() == Normal ) - copy(); - del(); - if ( textDirty && !d->isHandlingEvent ) - emit textChanged(); - } -} - -#endif - -/* - This private slot is activated when this line edit owns the clipboard and - some other widget/application takes over the clipboard. (X11 only) -*/ - -void TQtMultiLineEdit::clipboardChanged() -{ -#if defined(_WS_X11_) - disconnect( TQApplication::clipboard(), SIGNAL(dataChanged()), - this, SLOT(clipboardChanged()) ); - turnMark( FALSE ); - update(); -#endif -} - - -/* - Sets maxLineWidth() and maybe cellWidth() to \a w without updating the entire widget. - */ - -void TQtMultiLineEdit::setWidth( int w ) -{ - if ( w ==d->maxLineWidth ) - return; - bool u = autoUpdate(); - setAutoUpdate( FALSE ); - d->maxLineWidth = w; - if ( d->align == AlignLeft ) - setCellWidth( w ); - else - setCellWidth( TQMAX( w, contentsRect().width() ) ); - setAutoUpdate( u ); - if ( autoUpdate() && d->align != AlignLeft ) - update(); -} - - -/* - Sets the cursor position to character number \a col in line number \a line. - The parameters are adjusted to lie within the legal range. - - If \a mark is FALSE, the selection is cleared. otherwise it is extended - - \sa cursorPosition() -*/ - -void TQtMultiLineEdit::setCursorPosition( int line, int col, bool mark ) -{ - if ( mark && !hasMarkedText() ) { - markAnchorX = cursorX; - markAnchorY = cursorY; - } - int oldY = cursorY; - cursorY = TQMAX( TQMIN( line, numLines() - 1), 0 ); - cursorX = TQMAX( TQMIN( col, lineLength( cursorY )), 0 ); - curXPos = 0; - makeVisible(); - if ( mark ) { - newMark( cursorX, cursorY, FALSE ); - for ( int i = TQMIN(oldY,cursorY); i <= TQMAX(oldY,cursorY); i++ ) - updateCell( i, 0, FALSE ); - } else { - updateCell( oldY, 0, FALSE ); - turnMark( FALSE ); - } -} - - - -/* \obsolete - - Use getCursorPosition() instead. -*/ - -void TQtMultiLineEdit::cursorPosition( int *line, int *col ) const -{ - getCursorPosition(line,col); -} - - -/* - Returns the current line and character - position within that line, in the variables pointed to - by \a line and \a col respectively. - - \sa setCursorPosition() -*/ - -void TQtMultiLineEdit::getCursorPosition( int *line, int *col ) const -{ - if ( line ) - *line = cursorY; - if ( col ) - *col = cursorX; -} - - -/* - \sa setAutoUpdate() -*/ - -bool TQtMultiLineEdit::autoUpdate() const -{ - return TQtTableView::autoUpdate(); -} - - -/* - Sets the auto-update option of multi-line editor to \a enable. - -*/ - -void TQtMultiLineEdit::setAutoUpdate( bool enable ) -{ - TQtTableView::setAutoUpdate( enable ); -} - -/* - Sets the fixed height of the TQtMultiLineEdit so that \a lines text lines - are visible given the current font. - - \sa setMaxLines(), setFixedHeight() - */ -void TQtMultiLineEdit::setFixedVisibleLines( int lines ) -{ - int ls = fontMetrics().lineSpacing(); - setFixedHeight( frameWidth()*2 + ls*lines ); - return; -} - - - -/* - Returns the top center point where the cursor is drawn -*/ - -TQPoint TQtMultiLineEdit::cursorPoint() const -{ - TQPoint cp( 0, 0 ); - - TQFontMetrics fm( font() ); - int col, row; - col = row = 0; - cursorPosition( &row, &col ); - TQString line = textLine( row ); - ASSERT( line ); - cp.setX( d->lr_marg + textWidthWithTabs( fm, line, 0, col, d->align ) - 1 ); - cp.setY( (row * cellHeight()) + viewRect().y() ); - return cp; -} - - -/* \reimp -*/ -TQSizePolicy TQtMultiLineEdit::sizePolicy() const -{ - //### removeme 3.0 - return TQWidget::sizePolicy(); -} - - -/*\reimp -*/ -TQSize TQtMultiLineEdit::sizeHint() const -{ - constPolish(); - int expected_lines; - if ( d->maxlines >= 0 && d->maxlines <= 6 ) { - expected_lines = d->maxlines; - } else { - expected_lines = 6; - } - TQFontMetrics fm( font() ); - int h = fm.lineSpacing()*(expected_lines-1)+fm.height() + frameWidth()*2; - int w = fm.width('x')*35; - - int maxh = maximumSize().height(); - if ( maxh < TQWIDGETSIZE_MAX ) - h = maxh; - - return TQSize( w, h ).expandedTo( TQApplication::globalStrut() ); -} - - -/* - Returns a size sufficient for one character, and scroll bars. -*/ - -TQSize TQtMultiLineEdit::minimumSizeHint() const -{ - constPolish(); - TQFontMetrics fm( font() ); - int h = fm.lineSpacing() + frameWidth()*2; - int w = fm.maxWidth(); - h += frameWidth(); - w += frameWidth(); - if ( testTableFlags(Tbl_hScrollBar|Tbl_autoHScrollBar) ) - w += verticalScrollBar()->sizeHint().width(); - if ( testTableFlags(Tbl_vScrollBar|Tbl_autoVScrollBar) ) - h += horizontalScrollBar()->sizeHint().height(); - return TQSize(w,h); -} - - - -/*\reimp -*/ - -void TQtMultiLineEdit::resizeEvent( TQResizeEvent *e ) -{ - int oldw = contentsRect().width(); - TQtTableView::resizeEvent( e ); - if ( DYNAMIC_WRAP - && (e->oldSize().width() != width() - || oldw != contentsRect().width() ) ) { - bool oldAuto = autoUpdate(); - setAutoUpdate( FALSE ); - rebreakAll(); - if ( oldw != contentsRect().width() ) - rebreakAll(); - setAutoUpdate( oldAuto ); - if ( autoUpdate() ) - repaint( FALSE ); - } else if ( d->align != AlignLeft ) { - d->maxLineWidth = 0; // trigger update - updateCellWidth(); - } - if ( isVisible() ) - deselect(); -} - -/* - Sets the alignment to \a flags. Possible values are \c AlignLeft, \c - Align(H)Center and \c AlignRight. - - \sa alignment(), TQt::AlignmentFlags -*/ -void TQtMultiLineEdit::setAlignment( int flags ) -{ - if ( d->align != flags ) { - d->align = flags; - update(); - } -} - -/* - Returns the alignment. - -*/ -int TQtMultiLineEdit::alignment() const -{ - return d->align; -} - - -/* - Not supported at this time. - \a v is the validator to set. -*/ -void TQtMultiLineEdit::setValidator( const TQValidator *v ) -{ - d->val = v; - // #### validate text now -} - -/* - Not supported at this time. -*/ -const TQValidator * TQtMultiLineEdit::validator() const -{ - return d->val; -} - -/* \sa edited() -*/ -void TQtMultiLineEdit::setEdited( bool e ) -{ - d->edited = e; -} - -/* \sa setEdited() -*/ -bool TQtMultiLineEdit::edited() const -{ - return d->edited; -} - -/* \enum TQtMultiLineEdit::EchoMode - - This enum type describes the ways in which TQLineEdit can display its - contents. The currently defined values are: \list - - \i Normal - display characters as they are entered. This is - the default. - - \i NoEcho - do not display anything. - - \i Password - display asterisks instead of the characters - actually entered. - - \endlist - - \sa setEchoMode() echoMode() TQLineEdit::EchoMode -*/ - - -/* - Sets the echo mode to \a em. The default is \c Normal. - - The display is updated according. - - \sa setEchoMode() -*/ -void TQtMultiLineEdit::setEchoMode( EchoMode em ) -{ - if ( d->echomode != em ) { - d->echomode = em; - updateCellWidth(); - update(); - } -} - -/* - Returns the currently set echo mode. - - \sa setEchoMode() -*/ -TQtMultiLineEdit::EchoMode TQtMultiLineEdit::echoMode() const -{ - return d->echomode; -} - - -/* - Returns the string shown at line \a row, including - processing of the echoMode(). -*/ - -TQString TQtMultiLineEdit::stringShown(int row) const -{ - TQString* s = getString(row); - if ( !s ) return TQString::null; - switch ( d->echomode ) { - case Normal: - if (!*s) return TQString::fromLatin1(""); - return *s; - case Password: - { - TQString r; - r.fill(TQChar('*'), (int)s->length()); - if ( !r ) r = TQString::fromLatin1(""); - return r; - } - case NoEcho: - return TQString::fromLatin1(""); - } - return TQString::fromLatin1(""); -} - -/* - - \sa maxLength() -*/ -void TQtMultiLineEdit::setMaxLength(int m) -{ - d->maxlen = m; -} - -/* - \sa setMaxLength() -*/ -int TQtMultiLineEdit::maxLength() const -{ - return d->maxlen; -} - - -/* - Returns the length of the current text. - - \sa setMaxLength() - */ -int TQtMultiLineEdit::length() const -{ - int l = 0; - for ( TQtMultiLineEditRow* r = contents->first(); r; r = contents->next() ) { - l += r->s.length(); - if ( r->newline ) - ++l; - } - return l-1; -} - - -/* - Sets the maximum length of lines to \a m. Use -1 for unlimited - (the default). Existing long lines will be truncated. - - \sa maxLineLength() -*/ -void TQtMultiLineEdit::setMaxLineLength(int m) -{ - bool trunc = d->maxlinelen < 0 || m < d->maxlinelen; - d->maxlinelen = m; - if ( trunc ) { - TQtMultiLineEditRow* r = contents->first(); - while ( r ) { - r->s.truncate( m ); - r = contents->next(); - } - if ( cursorX > m ) cursorX = m; - if ( markAnchorX > m ) markAnchorX = m; - if ( markDragX > m ) markDragX = m; - update(); - updateCellWidth(); - } -} - -/* - Returns the currently set line length limit, or -1 if there is - no limit (this is the default). - - \sa setMaxLineLength() -*/ -int TQtMultiLineEdit::maxLineLength() const -{ - return d->maxlinelen; -} - -/* - Sets the maximum number of lines to \a m. Use -1 for unlimited - (the default). Existing excess lines will be deleted. - - \sa maxLines(), numLines() -*/ -void TQtMultiLineEdit::setMaxLines(int m) -{ - if ( m == 0 ) // bad value - m = -1; - d->maxlines = m; - if ( d->maxlines >= 0 && d->maxlines <= 6 ) { - setSizePolicy( TQSizePolicy( TQSizePolicy::Expanding, TQSizePolicy::Fixed ) ); - } else { - setSizePolicy( TQSizePolicy( TQSizePolicy::Expanding, TQSizePolicy::Expanding ) ); - } - if ( setNumRowsAndTruncate() ) { - updateCellWidth(); - update(); - } -} - -/* - \sa setMaxLines() -*/ -int TQtMultiLineEdit::maxLines() const -{ - return d->maxlines; -} - -/* - Sets the horizontal margin to \a m. - - \sa hMargin() -*/ -void TQtMultiLineEdit::setHMargin(int m) -{ - if ( m != d->lr_marg ) { - d->lr_marg = m; - updateCellWidth(); - update(); - } -} - -/* - - \sa setHMargin() -*/ -int TQtMultiLineEdit::hMargin() const -{ - return d->lr_marg; -} - -/* - Marks the text starting at \a row_from, \a col_from and ending - at \a row_to, \a col_to. -*/ -void TQtMultiLineEdit::setSelection( int row_from, int col_from, - int row_to, int col_to ) -{ - setCursorPosition( row_from, col_from, FALSE ); - setCursorPosition( row_to, col_to, TRUE ); -} - - -/* - Moves the cursor one word to the right. If \a mark is TRUE, the text - is marked. - \sa cursorWordBackward() -*/ -void TQtMultiLineEdit::cursorWordForward( bool mark ) -{ - int x = cursorX; - int y = cursorY; - - if ( x == lineLength( y ) || textLine(y).at(x).isSpace() ) { - while ( x < lineLength( y ) && textLine(y).at(x).isSpace() ) - ++x; - if ( x == lineLength( y ) ) { - if ( y < (int)contents->count() - 1) { - ++y; - x = 0; - while ( x < lineLength( y ) && textLine(y).at(x).isSpace() ) - ++x; - } - } - } - else { - while ( x < lineLength( y ) && !textLine(y).at(x).isSpace() ) - ++x; - int xspace = x; - while ( xspace < lineLength( y ) && textLine(y).at(xspace).isSpace() ) - ++xspace; - if ( xspace < lineLength( y ) ) - x = xspace; - } - cursorOn = TRUE; - int oldY = cursorY; - setCursorPosition( y, x, mark ); - if ( oldY != cursorY ) - updateCell( oldY, 0, FALSE ); - updateCell( cursorY, 0, FALSE ); - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); -} - -/* - Moves the cursor one word to the left. If \a mark is TRUE, the text - is marked. - \sa cursorWordForward() -*/ -void TQtMultiLineEdit::cursorWordBackward( bool mark ) -{ - int x = cursorX; - int y = cursorY; - - while ( x > 0 && textLine(y).at(x-1).isSpace() ) - --x; - - if ( x == 0 ) { - if ( y > 0 ) { - --y; - x = lineLength( y ); - while ( x > 0 && textLine(y).at(x-1).isSpace() ) - --x; - } - } - else { - while ( x > 0 && !textLine(y).at(x-1).isSpace() ) - --x; - } - cursorOn = TRUE; - int oldY = cursorY; - setCursorPosition( y, x, mark ); - if ( oldY != cursorY ) - updateCell( oldY, 0, FALSE ); - updateCell( cursorY, 0, FALSE ); - d->blinkTimer->start( TQApplication::cursorFlashTime() / 2, FALSE ); -} - -#define DO_BREAK {doBreak = TRUE; if ( lastSpace > a ) { \ -i = lastSpace; \ -linew = lastw; \ -} \ -else \ -i = TQMAX( a, i-1 );} - -void TQtMultiLineEdit::wrapLine( int line, int removed ) -{ - TQtMultiLineEditRow* r = contents->at( line ); - int yPos; - (void) rowYPos( line, &yPos ); - TQFontMetrics fm( font() ); - int i = 0; - TQString s = r->s; - int a = 0; - int l = line; - int w = 0; - int nlines = 0; - int lastSpace = -1; - bool doBreak = FALSE; - int linew = 0; - int lastw = 0; - int tabDist = -1; // lazy eval - while ( i < int(s.length()) ) { - doBreak = FALSE; - if ( s[i] == '\t' && d->align == TQt::AlignLeft ) { - if ( tabDist<0 ) - tabDist = tabStopDist(fm); - linew = ( linew/tabDist + 1 ) * tabDist; - } else if ( s[i] != '\n' ) { - char c = s[i].latin1(); - if ( c > 0 ) { - if ( !d->chartable[c] ) - d->chartable[c] = fm.width( s[i] ); - linew += d->chartable[c]; - } else { - linew += fm.width( s[i] ); - } - } - if ( WORD_WRAP && - lastSpace >= a && s[i] != '\n' ) { - if ( DYNAMIC_WRAP ) { - if (linew >= contentsRect().width() - 2*d->lr_marg - d->marg_extra) { - DO_BREAK - } - } else if ( FIXED_COLUMN_WRAP ) { - if ( d->wrapcol >= 0 && i-a >= d->wrapcol ) { - DO_BREAK - } - } else if ( FIXED_WIDTH_WRAP ) { - if ( d->wrapcol >= 0 && linew > d->wrapcol - d->marg_extra ) { - DO_BREAK - } - } - } - if ( s[i] == '\n' || doBreak ) { - r->s = s.mid( a, i - a + (doBreak?1:0) ); - r->w = linew - fm.leftBearing(r->s[0]) + 2 * d->lr_marg + d->marg_extra; - if ( r->w > w ) - w = r->w; - if ( cursorY > l ) - ++cursorY; - else if ( cursorY == line && cursorX >=a && cursorX <= i + (doBreak?1:0)) { - cursorY = l; - cursorX -= a; - } - if ( markAnchorY > l ) - ++markAnchorY; - else if ( markAnchorY == line && markAnchorX >=a && markAnchorX <= i + (doBreak?1:0)) { - markAnchorY = l; - markAnchorX -= a; - } - a = i + 1; - lastSpace = a; - linew = 0; - bool oldnewline = r->newline; - r->newline = !doBreak; - r = new TQtMultiLineEditRow( TQString::null, 0, oldnewline ); - ++nlines; - contents->insert( l + 1, r ); - ++l; - } - if ( s[i].isSpace() || BREAK_WITHIN_WORDS ) { - lastSpace = i; - lastw = linew; - } - if ( lastSpace <= a ) - lastw = linew; - - ++i; - } - if ( a < int(s.length()) ){ - r->s = s.mid( a, i - a ); - r->w = linew - fm.leftBearing( r->s[0] ) + 2 * d->lr_marg + d->marg_extra; - } - if ( cursorY == line && cursorX >= a ) { - cursorY = l; - cursorX -= a; - } - if ( markAnchorY == line && markAnchorX >= a ) { - markAnchorY = l; - markAnchorX -= a; - } - if ( r->w > w ) - w = r->w; - - setWidth( TQMAX( maxLineWidth(), w ) ); - bool oldAuto = autoUpdate(); - setAutoUpdate( FALSE ); - (void)setNumRowsAndTruncate(); - setAutoUpdate( oldAuto ); - - yPos += (nlines+1) * cellHeight(); - int sh = (nlines-removed) * cellHeight(); - if ( autoUpdate() ) { - if ( sh && yPos >= contentsRect().top() && yPos < contentsRect().bottom() ) { - int h = contentsRect().bottom() - yPos + 1; - if ( d->maxlines >= 0 ) { - int maxy; - if ( rowYPos( d->maxlines-1, &maxy ) ) { - maxy += cellHeight(); - if ( maxy < contentsRect().bottom() && maxy > yPos ) - h = maxy - yPos + 1; - } - } - TQWidget::scroll( 0, sh, TQRect( contentsRect().left(), yPos, - contentsRect().width(), - h ) ); - } - for (int ul = 0; ul <= nlines; ++ul ) - updateCell( line + ul, 0, FALSE ); - } -} - -void TQtMultiLineEdit::rebreakParagraph( int line, int removed ) -{ - TQtMultiLineEditRow* r = contents->at( line ); - if ( WORD_WRAP ) { - TQtMultiLineEditRow* other = 0; - while (line < int(contents->count())-1 && !r->newline ) { - other = contents->at( line + 1 ); - if ( cursorY > line ) { - --cursorY; - if ( cursorY == line ) { - cursorX += r->s.length(); - } - } - if ( markAnchorY > line ) { - --markAnchorY; - if ( markAnchorY == line ) { - markAnchorX += r->s.length(); - } - } - r->s.append( other->s ); - r->newline = other->newline; - contents->remove( line + 1 ); - ++removed; - } - } - wrapLine( line, removed ); -} - -void TQtMultiLineEdit::rebreakAll() -{ - if ( !WORD_WRAP ) - return; - d->maxLineWidth = 0; - for (int i = 0; i < int(contents->count()); ++i ) { - if ( contents->at( i )->newline && - contents->at( i )->w < contentsRect().width() - 2*d->lr_marg - d->marg_extra ) { - setWidth( TQMAX( d->maxLineWidth, contents->at( i )->w ) ); - continue; - } - rebreakParagraph( i ); - while ( i < int(contents->count() ) - && !contents->at( i )->newline ) - ++i; - } -} - - -/* \enum TQtMultiLineEdit::WordWrap - - This enum describes the multiline edit's word wrap mode. - - The following values are valid: - \list - \i NoWrap - no word wrap at all. - \i WidgetWidth - word wrap depending on the current - width of the editor widget - \i FixedPixelWidth - wrap according to a fix amount - of pixels ( see wrapColumnOrWidth() ) - \i FixedColumnWidth - wrap according to a fix character - column. This is useful whenever you need formatted text that - can also be displayed gracefully on devices with monospaced - fonts, for example a standard VT100 terminal. In that case - wrapColumnOrWidth() should typically be set to 80. - \endlist - - \sa setWordWrap() -*/ - -/* - Sets the word wrap mode to \a mode. - - */ -void TQtMultiLineEdit::setWordWrap( WordWrap mode ) -{ - if ( mode == d->wordwrap ) - return; - d->wordwrap = mode; - - if ( BREAK_WITHIN_WORDS ) { - d->arrow = TQPixmap( (const char **)arrow_xpm ); - d->marg_extra = 8; - if ( DYNAMIC_WRAP ) - clearTableFlags( Tbl_autoHScrollBar ); - else - setTableFlags( Tbl_autoHScrollBar ); - } else { - d->marg_extra = 0; - setTableFlags( Tbl_autoHScrollBar ); - } - if ( !text().isEmpty() ) - setText( text() ); -} - -/* - Returns the current word wrap mode. - - \sa setWordWrap() - */ -TQtMultiLineEdit::WordWrap TQtMultiLineEdit::wordWrap() const -{ - return d->wordwrap; -} - -/* - Sets the wrap column or wrap width to \a value, depending on the - word wrap mode. - - \sa setWordWrap() - */ -void TQtMultiLineEdit::setWrapColumnOrWidth( int value ) -{ - if ( value == d->wrapcol ) - return; - d->wrapcol = value; - if ( wordWrap() != NoWrap ) - setText( text() ); -} - -/* - */ -int TQtMultiLineEdit::wrapColumnOrWidth() const -{ - return d->wrapcol; -} - - -/* \enum TQtMultiLineEdit::WrapPolicy - - Defines where text can be wrapped in word wrap mode. - - The following values are valid: - \list - \i AtWhiteSpace - break only after whitespace - \i Anywhere - break anywhere - \endlist - - \sa setWrapPolicy() -*/ - -/* - Sets the wrap \a policy, i.e. where text can be wrapped in word wrap - mode. - - \sa setWordWrap(), wrapPolicy() - */ -void TQtMultiLineEdit::setWrapPolicy( WrapPolicy policy ) -{ - if ( d->wrappolicy == policy ) - return; - d->wrappolicy = policy; - WordWrap m = d->wordwrap; - if ( m != NoWrap ) { // trigger update - d->wordwrap = NoWrap; - setWordWrap( m ); - } -} - -/* - - Returns the current word wrap policy. - - \sa setWrapPolicy() - */ -TQtMultiLineEdit::WrapPolicy TQtMultiLineEdit::wrapPolicy() const -{ - return d->wrappolicy; -} - -/* - Returns wether \a row is the last row in a paragraph. - - This function is only interesting in word wrap mode, otherwise its - return value is always TRUE. - - \sa setWordWrap() - */ -bool TQtMultiLineEdit::isEndOfParagraph( int row ) const -{ - return contents->at( row )->newline; -} - -int TQtMultiLineEdit::positionToOffsetInternal( int row, int col ) const -{ - row = TQMAX( TQMIN( row, numLines() - 1), 0 ); // Sanity check - col = TQMAX( TQMIN( col, lineLength( row )), 0 ); // Sanity check - if ( row == 0 ) - return TQMIN( col, lineLength( 0 )); - else { - int lastI; - lastI = lineLength( row ); - int i, tmp = 0; - - for( i = 0; i < row ; i++ ) { - tmp += lineLength( i ); - if ( contents->at( i )->newline ) - ++tmp; - } - - tmp += TQMIN( lastI, col ); - - return tmp; - } - -} - -// if position is <0 = returns row 0, col 0, if position >= amount of text -// returns pointer to end of text. -void TQtMultiLineEdit::offsetToPositionInternal( int position, - int *row, int *col ) const -{ - if (position <= 0) { - *row = 0; - *col = 0; - return; - } - else { - int charsLeft = position; - int i; - - for( i = 0; contents->at( i ); ++i ) { - if (lineLength( i ) < charsLeft) - charsLeft -= lineLength( i ); - else { - *row = i; - *col = charsLeft; - return; - } - if ( contents->at( i )->newline ) - --charsLeft; - } - - if (contents->at( i - 1) && !contents->at( i - 1 )->newline) { - *row = i - 1; - *col = lineLength( i - 1 ); - } - else { - *row = i; - *col = 0; - } - return; - } -} - - -/* - Processes an undo/redo command \a cmd, depending on \a undo. - */ -void TQtMultiLineEdit::processCmd( TQtMultiLineEditCommand* cmd, bool undo) -{ - TQDelTextCmd* delcmd = (TQDelTextCmd*) cmd; - bool ins = TRUE; - if (cmd->type() == TQtMultiLineEditCommand::Delete ) - ins = undo; - else if (cmd->type() == TQtMultiLineEditCommand::Insert ) - ins = !undo; - else - return; - - if ( ins ) { - int row, col; - offsetToPositionInternal( delcmd->mOffset, &row, &col ); - setCursorPosition( row, col, FALSE ); - insertAt( delcmd->mStr, row, col, FALSE ); - offsetToPositionInternal( delcmd->mOffset+delcmd->mStr.length(), &row, &col ); - setCursorPosition( row, col, FALSE ); - } else { // del - int row, col, rowEnd, colEnd; - offsetToPositionInternal( delcmd->mOffset, &row, &col ); - offsetToPositionInternal( delcmd->mOffset + delcmd->mStr.length(), &rowEnd, &colEnd ); - markAnchorY = row; - markAnchorX = col; - setCursorPosition( rowEnd, colEnd, FALSE ); - markDragY = rowEnd; - markDragX = colEnd; - turnMark( TRUE ); - del(); - } -} - -/* - Undoes the last text operation. - */ -void TQtMultiLineEdit::undo() -{ - if ( d->undoList.isEmpty() || isReadOnly() ) - return; - textDirty = FALSE; - int macroLevel = 0; - bool before = d->undo; - d->undo = FALSE; - do { - TQtMultiLineEditCommand *command = d->undoList.take(); - if ( !command ) - break; - processCmd( command, TRUE ); - macroLevel += command->terminator(); - if ( d->undoList.isEmpty() ) - emit undoAvailable( FALSE ); - addRedoCmd( command ); - } while (macroLevel != 0); - d->undo = before; - if ( textDirty ) - emit textChanged(); - textDirty = FALSE; -} - -/* - Redoes the last text operation. - */ -void TQtMultiLineEdit::redo() -{ - if ( d->redoList.isEmpty() || isReadOnly() ) - return; - textDirty = FALSE; - int macroLevel = 0; - bool before = d->undo; - d->undo = FALSE; - do { - TQtMultiLineEditCommand *command = d->redoList.take(); - if ( !command ) - break; - processCmd( command, FALSE ); - macroLevel += command->terminator(); - if ( d->redoList.isEmpty() ) - emit redoAvailable( FALSE ); - if ( d->undoList.isEmpty() ) - emit undoAvailable(TRUE); - d->undoList.append( command ); - } while (macroLevel != 0); - d->undo = before; - if ( textDirty ) - emit textChanged(); - textDirty = FALSE; -} - -/* - Inserts \a s at line number \a line, after character number \a col - in the line. - If \a s contains newline characters, new lines are inserted. - If \a mark is TRUE the inserted text is selected. - - The cursor position is adjusted. If the insertion position is equal to - the cursor position, the cursor is placed after the end of the new text. - - */ - -void TQtMultiLineEdit::insertAt( const TQString &s, int line, int col, bool mark ) -{ - if ( d->undo ) { - d->undo = FALSE; - TQString itxt = s; - int offset = positionToOffsetInternal( line, col ); - if ( d->maxlen >= 0 && length() + int(s.length()) > d->maxlen ) - itxt.truncate( d->maxlen - length() ); - addUndoCmd( new TQInsTextCmd( offset, itxt ) ); - insertAtAux( s, line, col, mark ); // may perform del op - d->undo = TRUE; - } - else - insertAtAux( s, line, col, mark ); // may perform del op -} - -void TQtMultiLineEdit::deleteNextChar( int offset, int row, int col ) -{ - int row2, col2; - setCursorPosition( row, col, FALSE ); - offsetToPositionInternal( offset + 1, &row2, &col2 ); - setCursorPosition( row2, col2, TRUE ); - - TQString str = markedText(); - addUndoCmd( new TQDelTextCmd( offset, str ) ); - - setCursorPosition( row, col, FALSE ); -} - -/* - Deletes text from the current cursor position to the end of the line. -*/ - -void TQtMultiLineEdit::killLine() -{ - if ( d->undo ) { - d->undo = FALSE; - int curY, curX; - cursorPosition( &curY, &curX ); - int offset = positionToOffsetInternal( curY, curX ); - TQtMultiLineEditRow* r = contents->at( curY ); - deselect(); - - addUndoCmd( new TQBeginCommand ); - if (curX == (int)r->s.length()) { - if ( ! atEnd() && r->newline ) - deleteNextChar( offset, curY, curX ); - } - else { - TQString str = r->s.mid( curX, r->s.length() ); - addUndoCmd( new TQDelTextCmd( offset, str ) ); - } - - addUndoCmd( new TQEndCommand ); - killLineAux(); - d->undo = TRUE; - } - else - killLineAux(); -} - -/* - Deletes the character on the right side of the text cursor. If a - text has been marked by the user (e.g. by clicking and dragging) the - cursor is put at the beginning of the marked text and the marked - text is removed. \sa backspace() -*/ - -void TQtMultiLineEdit::del() -{ - if (d->undo ) { - d->undo = FALSE; - bool oldAuto = autoUpdate(); - setAutoUpdate( FALSE ); - int markBeginX, markBeginY; - int markEndX, markEndY; - - if ( getMarkedRegion( &markBeginY, &markBeginX, &markEndY, &markEndX ) ) { - addUndoCmd( new TQBeginCommand ); - int offset = positionToOffsetInternal( markBeginY, markBeginX ); - TQString str = markedText(); - d->undoList.append( new TQDelTextCmd( offset, str ) ); - addUndoCmd( new TQEndCommand ); - } - else if ( ! atEnd() ) { - int crsorY, crsorX; - cursorPosition( &crsorY, &crsorX ); - int offset = positionToOffsetInternal( crsorY, crsorX ); - TQtMultiLineEditRow* r = contents->at( crsorY ); - if (r) { - if (crsorX != (int)r->s.length()) - deleteNextChar( offset, crsorY, crsorX ); - else if (r->newline) - deleteNextChar( offset, crsorY, crsorX ); - // else noop - } - } - setAutoUpdate( oldAuto ); - delAux(); - d->undo = TRUE; - } - else - delAux(); -} - -/* - Sets undo enabled to \a enable. - - \sa isUndoEnabled() -*/ -void TQtMultiLineEdit::setUndoEnabled( bool enable ) -{ - if ( d->undo == enable ) - return; - d->undo = enable; - if ( !enable ) { - CLEAR_UNDO - } -} - - -/* - Returns whether the multilineedit is currently undo enabled or not. - - \sa setUndoEnabled() - */ -bool TQtMultiLineEdit::isUndoEnabled() const -{ - return d->undo; -} - - -/* - Sets the maximum number of operations that can be stored on the undo - stack to \a depth. - - \sa undoDepth() - */ -void TQtMultiLineEdit::setUndoDepth( int depth ) -{ - d->undodepth = depth; -} - - -/* - */ -int TQtMultiLineEdit::undoDepth() const -{ - return d->undodepth; -} - -void TQtMultiLineEdit::blinkTimerTimeout() -{ - cursorOn = !cursorOn; - updateCell( cursorY, 0, FALSE ); -} - -void TQtMultiLineEdit::scrollTimerTimeout() -{ - TQPoint p = mapFromGlobal( TQCursor::pos() ); - if ( d->scrollAccel-- <= 0 && d->scrollTime ) { - d->scrollAccel = initialScrollAccel; - d->scrollTime--; - d->scrollTimer->stop(); - d->scrollTimer->start( d->scrollTime ); - } - int l = TQMAX(1,(initialScrollTime-d->scrollTime)/5); - - // auto scrolling is dual-use - for highlighting and DND - int margin = d->dnd_primed ? scroll_margin : 0; - bool mark = !d->dnd_primed; - bool clear_mark = d->dnd_primed ? FALSE : !mark; - - for (int i=0; i<l; i++) { - if ( p.y() < margin ) { - cursorUp( mark, clear_mark ); - } else if ( p.y() > height()-margin ) { - cursorDown( mark, clear_mark ); - } else if ( p.x() < margin ) { - cursorLeft( mark, clear_mark, FALSE ); - } else if ( p.x() > width()-margin ) { - cursorRight( mark, clear_mark, FALSE ); - } else { - stopAutoScroll(); - break; - } - } -} - -void TQtMultiLineEdit::dndTimeout() -{ -#ifndef TQT_NO_DRAGANDDROP - doDrag(); -#endif -} - -int TQtMultiLineEdit::setNumRowsAndTruncate() -{ - int n = contents->count(); - int r = 0; - while ( d->maxlines >= 0 && n > d->maxlines ) { - // truncate - contents->at(n-2)->newline = TRUE; - contents->removeLast(); - if ( markAnchorY == n-1 ) - markAnchorY--; - if ( markDragY == n-1 ) - markDragY--; - if ( cursorY == n-1 ) { - cursorY--; - cursorX = contents->at(cursorY)->s.length(); - } - n--; - r++; - } - setNumRows( n ); - return r; -} - -/* \reimp -*/ -bool TQtMultiLineEdit::event( TQEvent * e ) -{ - if ( e->type() == TQEvent::AccelOverride && !isReadOnly() ) { - TQKeyEvent* ke = (TQKeyEvent*) e; - if ( ke->state() & ControlButton ) { - switch ( ke->key() ) { - case Key_A: - case Key_E: -#if defined (_WS_WIN_) - case Key_Insert: -#endif - case Key_X: - case Key_V: - case Key_C: - case Key_Left: - case Key_Right: - case Key_Up: - case Key_Down: - case Key_Home: - case Key_End: - ke->accept(); - default: - break; - } - } else { - switch ( ke->key() ) { - case Key_Delete: - case Key_Home: - case Key_End: - case Key_Backspace: - ke->accept(); - default: - break; - } - } - } - return TQWidget::event( e ); -} - -/* \reimp -*/ - -bool TQtMultiLineEdit::focusNextPrevChild( bool ) -{ - return FALSE; -} - -#endif diff --git a/src/attic/qtmultilineedit.h b/src/attic/qtmultilineedit.h deleted file mode 100644 index 10573e3dd..000000000 --- a/src/attic/qtmultilineedit.h +++ /dev/null @@ -1,363 +0,0 @@ -/********************************************************************** -** -** Definition of TQtMultiLineEdit widget class -** -** Created : 961005 -** -** Copyright (C) 1992-2008 Trolltech ASA. All rights reserved. -** -** This file contains a class moved out of the TQt GUI Toolkit API. It -** may be used, distributed and modified without limitation. -** -**********************************************************************/ - -#ifndef TQTMULTILINEEDIT_H -#define TQTMULTILINEEDIT_H - -#ifndef QT_H -#include "qttableview.h" -#include "ntqstring.h" -#include "ntqptrlist.h" -#endif // QT_H - -#ifndef TQT_NO_QTMULTILINEEDIT - -struct TQtMultiLineData; -class TQtMultiLineEditCommand; -class TQValidator; - -class TQtMultiLineEdit : public TQtTableView -{ - TQ_OBJECT - TQ_ENUMS( EchoMode WordWrap WrapPolicy ) - TQ_PROPERTY( int numLines READ numLines ) - TQ_PROPERTY( bool atBeginning READ atBeginning ) - TQ_PROPERTY( bool atEnd READ atEnd ) - TQ_PROPERTY( int maxLineWidth READ maxLineWidth ) - TQ_PROPERTY( Alignment alignment READ alignment WRITE setAlignment ) - TQ_PROPERTY( bool edited READ edited WRITE setEdited DESIGNABLE false ) - TQ_PROPERTY( EchoMode echoMode READ echoMode WRITE setEchoMode ) - TQ_PROPERTY( int maxLength READ maxLength WRITE setMaxLength ) - TQ_PROPERTY( int maxLines READ maxLines WRITE setMaxLines ) - TQ_PROPERTY( int hMargin READ hMargin WRITE setHMargin ) - TQ_PROPERTY( WordWrap wordWrap READ wordWrap WRITE setWordWrap ) - TQ_PROPERTY( int wrapColumnOrWidth READ wrapColumnOrWidth WRITE setWrapColumnOrWidth ) - TQ_PROPERTY( WrapPolicy wrapPolicy READ wrapPolicy WRITE setWrapPolicy ) - TQ_PROPERTY( bool autoUpdate READ autoUpdate WRITE setAutoUpdate DESIGNABLE false ) - TQ_PROPERTY( bool undoEnabled READ isUndoEnabled WRITE setUndoEnabled ) - TQ_PROPERTY( int undoDepth READ undoDepth WRITE setUndoDepth ) - TQ_PROPERTY( bool readOnly READ isReadOnly WRITE setReadOnly ) - TQ_PROPERTY( bool overWriteMode READ isOverwriteMode WRITE setOverwriteMode ) - TQ_PROPERTY( TQString text READ text WRITE setText ) - TQ_PROPERTY( int length READ length ) - -public: - TQtMultiLineEdit( TQWidget *parent=0, const char *name=0 ); - ~TQtMultiLineEdit(); - - TQString textLine( int line ) const; - int numLines() const; - - TQSize sizeHint() const; - TQSize minimumSizeHint() const; - TQSizePolicy sizePolicy() const; - - virtual void setFont( const TQFont &font ); - - virtual void insertLine( const TQString &s, int line = -1 ); - virtual void insertAt( const TQString &s, int line, int col, bool mark = FALSE ); - virtual void removeLine( int line ); - - void cursorPosition( int *line, int *col ) const; - virtual void setCursorPosition( int line, int col, bool mark = FALSE ); - void getCursorPosition( int *line, int *col ) const; - bool atBeginning() const; - bool atEnd() const; - - virtual void setFixedVisibleLines( int lines ); - - int maxLineWidth() const; - - void setAlignment( int flags ); - int alignment() const; - - virtual void setValidator( const TQValidator * ); - const TQValidator * validator() const; - - void setEdited( bool ); - bool edited() const; - - void cursorWordForward( bool mark ); - void cursorWordBackward( bool mark ); - - enum EchoMode { Normal, NoEcho, Password }; - virtual void setEchoMode( EchoMode ); - EchoMode echoMode() const; - - void setMaxLength(int); - int maxLength() const; - virtual void setMaxLineLength(int); - int maxLineLength() const; - virtual void setMaxLines(int); - int maxLines() const; - virtual void setHMargin(int); - int hMargin() const; - - virtual void setSelection( int row_from, int col_from, int row_to, int col_t ); - - enum WordWrap { - NoWrap, - WidgetWidth, - FixedPixelWidth, - FixedColumnWidth - }; - void setWordWrap( WordWrap mode ); - WordWrap wordWrap() const; - void setWrapColumnOrWidth( int ); - int wrapColumnOrWidth() const; - - enum WrapPolicy { - AtWhiteSpace, - Anywhere - }; - void setWrapPolicy( WrapPolicy policy ); - WrapPolicy wrapPolicy() const; - - bool autoUpdate() const; - virtual void setAutoUpdate( bool ); - - void setUndoEnabled( bool ); - bool isUndoEnabled() const; - void setUndoDepth( int ); - int undoDepth() const; - - bool isReadOnly() const; - bool isOverwriteMode() const; - - TQString text() const; - - int length() const; - - static void setDefaultTabStop( int ex ); - static int defaultTabStop(); -public slots: - virtual void setText( const TQString &); - virtual void setReadOnly( bool ); - virtual void setOverwriteMode( bool ); - - void clear(); - void append( const TQString &); - void deselect(); - void selectAll(); -#ifndef TQT_NO_CLIPBOARD - void paste(); - void pasteSubType(const TQCString& subtype); - void copyText() const; - void copy() const; - void cut(); -#endif - void insert( const TQString& ); - void undo(); - void redo(); - -signals: - void textChanged(); - void returnPressed(); - void undoAvailable( bool ); - void redoAvailable( bool ); - void copyAvailable( bool ); - -protected: - void paintCell( TQPainter *, int row, int col ); - bool event( TQEvent * ); - - void mousePressEvent( TQMouseEvent * ); - void mouseMoveEvent( TQMouseEvent * ); - void mouseReleaseEvent( TQMouseEvent * ); - void mouseDoubleClickEvent( TQMouseEvent * ); - void wheelEvent( TQWheelEvent * ); - void keyPressEvent( TQKeyEvent * ); - void focusInEvent( TQFocusEvent * ); - void focusOutEvent( TQFocusEvent * ); - void timerEvent( TQTimerEvent * ); - void leaveEvent( TQEvent * ); - void resizeEvent( TQResizeEvent * ); - - bool focusNextPrevChild( bool ); - -#ifndef TQT_NO_DRAGANDDROP - void dragMoveEvent( TQDragMoveEvent* ); - void dragEnterEvent( TQDragEnterEvent * ); - void dropEvent( TQDropEvent* ); - void dragLeaveEvent( TQDragLeaveEvent* ); -#endif - - bool hasMarkedText() const; - TQString markedText() const; - int textWidth( int ); - int textWidth( const TQString &); - - TQPoint cursorPoint() const; - -protected: - virtual void insert( const TQString&, bool mark ); - virtual void newLine(); - virtual void killLine(); - virtual void pageUp( bool mark=FALSE ); - virtual void pageDown( bool mark=FALSE ); - virtual void cursorLeft( bool mark=FALSE, bool wrap = TRUE ); - virtual void cursorRight( bool mark=FALSE, bool wrap = TRUE ); - virtual void cursorUp( bool mark=FALSE ); - virtual void cursorDown( bool mark=FALSE ); - virtual void backspace(); - virtual void del(); - virtual void home( bool mark=FALSE ); - virtual void end( bool mark=FALSE ); - - bool getMarkedRegion( int *line1, int *col1, - int *line2, int *col2 ) const; - int lineLength( int row ) const; - TQString *getString( int row ) const; - bool isEndOfParagraph( int row ) const; - TQString stringShown( int row ) const; - -protected: - bool cursorOn; - void insertChar( TQChar ); - -private slots: - void clipboardChanged(); - void blinkTimerTimeout(); - void scrollTimerTimeout(); - void dndTimeout(); - -private: -#ifndef TQT_NO_MIME - TQCString pickSpecial(TQMimeSource* ms, bool always_ask, const TQPoint&); -#endif -#ifndef TQT_NO_MIMECLIPBOARD - void pasteSpecial(const TQPoint&); -#endif - struct TQtMultiLineEditRow { - TQtMultiLineEditRow( TQString string, int width, bool nl = TRUE ) - :s(string), w(width), newline( nl ) - { - }; - TQString s; - int w; - bool newline; - }; - TQPtrList<TQtMultiLineEditRow> *contents; - TQtMultiLineData *d; - - bool readOnly; - bool dummy; - bool markIsOn; - bool dragScrolling ; - bool dragMarking; - bool textDirty; - bool wordMark; - bool overWrite; - - int cursorX; - int cursorY; - int markAnchorX; - int markAnchorY; - int markDragX; - int markDragY; - int curXPos; // cell coord of cursor - int blinkTimer; // #### not used anymore - remove in 3.0 - int scrollTimer; // #### not used anymore - remove in 3.0 - - int mapFromView( int xPos, int row ); - int mapToView( int xIndex, int row ); - - void pixelPosToCursorPos(TQPoint p, int* x, int* y) const; - void setCursorPixelPosition(TQPoint p, bool clear_mark=TRUE); - - void setWidth( int ); - void updateCellWidth(); - bool partiallyInvisible( int row ); - void makeVisible(); - void setBottomCell( int row ); - - void newMark( int posx, int posy, bool copy=TRUE ); - void markWord( int posx, int posy ); - void extendSelectionWord( int &newX, int&newY); - int charClass( TQChar ); - void turnMark( bool on ); - bool inMark( int posx, int posy ) const; - bool beforeMark( int posx, int posy ) const; - bool afterMark( int posx, int posy ) const; - int setNumRowsAndTruncate(); - -#ifndef TQT_NO_DRAGANDDROP - void doDrag(); -#endif - void startAutoScroll(); - void stopAutoScroll(); - - void cursorLeft( bool mark, bool clear_mark, bool wrap ); - void cursorRight( bool mark, bool clear_mark, bool wrap ); - void cursorUp( bool mark, bool clear_mark ); - void cursorDown( bool mark, bool clear_mark ); - - void wrapLine( int line, int removed = 0); - void rebreakParagraph( int line, int removed = 0 ); - void rebreakAll(); - void insertAtAux( const TQString &s, int line, int col, bool mark = FALSE ); - void killLineAux(); - void delAux(); - int positionToOffsetInternal( int row, int col ) const; - void offsetToPositionInternal( int position, int *row, int *col ) const; - void deleteNextChar( int offset, int row, int col ); - - void addUndoCmd( TQtMultiLineEditCommand* ); - void addRedoCmd( TQtMultiLineEditCommand* ); - void processCmd( TQtMultiLineEditCommand*, bool ); - -private: // Disabled copy constructor and operator= -#if defined(TQ_DISABLE_COPY) - TQtMultiLineEdit( const TQtMultiLineEdit & ); - TQtMultiLineEdit &operator=( const TQtMultiLineEdit & ); -#endif -}; - -inline bool TQtMultiLineEdit::isReadOnly() const { return readOnly; } - -inline bool TQtMultiLineEdit::isOverwriteMode() const { return overWrite; } - -inline void TQtMultiLineEdit::setOverwriteMode( bool on ) -{ - overWrite = on; - } - -inline int TQtMultiLineEdit::lineLength( int row ) const -{ - return contents->at( row )->s.length(); -} - -inline bool TQtMultiLineEdit::atEnd() const -{ - return cursorY == (int)contents->count() - 1 - && cursorX == lineLength( cursorY ) ; -} - -inline bool TQtMultiLineEdit::atBeginning() const -{ - return cursorY == 0 && cursorX == 0; -} - -inline TQString *TQtMultiLineEdit::getString( int row ) const -{ - return &(contents->at( row )->s); -} - -inline int TQtMultiLineEdit::numLines() const -{ - return contents->count(); -} - -#endif // TQT_NO_QTMULTILINEEDIT - -#endif // TQTMULTILINEDIT_H diff --git a/src/attic/qttableview.cpp b/src/attic/qttableview.cpp deleted file mode 100644 index ea55a9ff6..000000000 --- a/src/attic/qttableview.cpp +++ /dev/null @@ -1,2272 +0,0 @@ -/********************************************************************** -** -** Implementation of TQtTableView class -** -** Created : 941115 -** -** Copyright (C) 1992-2008 Trolltech ASA. All rights reserved. -** -** This file contains a class moved out of the TQt GUI Toolkit API. It -** may be used, distributed and modified without limitation. -** -**********************************************************************/ - -#include "qttableview.h" -#ifndef TQT_NO_QTTABLEVIEW -#include "ntqscrollbar.h" -#include "ntqpainter.h" -#include "ntqdrawutil.h" -#include <limits.h> - -enum ScrollBarDirtyFlags { - verGeometry = 0x01, - verSteps = 0x02, - verRange = 0x04, - verValue = 0x08, - horGeometry = 0x10, - horSteps = 0x20, - horRange = 0x40, - horValue = 0x80, - verMask = 0x0F, - horMask = 0xF0 -}; - - -#define HSBEXT horizontalScrollBar()->sizeHint().height() -#define VSBEXT verticalScrollBar()->sizeHint().width() - - -class TQCornerSquare : public TQWidget // internal class -{ -public: - TQCornerSquare( TQWidget *, const char* = 0 ); - void paintEvent( TQPaintEvent * ); -}; - -TQCornerSquare::TQCornerSquare( TQWidget *parent, const char *name ) - : TQWidget( parent, name ) -{ -} - -void TQCornerSquare::paintEvent( TQPaintEvent * ) -{ -} - - -// NOT REVISED -/* - \class TQtTableView qttableview.h - \brief The TQtTableView class provides an abstract base for tables. - - \obsolete - - A table view consists of a number of abstract cells organized in rows - and columns, and a visible part called a view. The cells are identified - with a row index and a column index. The top-left cell is in row 0, - column 0. - - The behavior of the widget can be finely tuned using - setTableFlags(); a typical subclass will consist of little more than a - call to setTableFlags(), some table content manipulation and an - implementation of paintCell(). Subclasses that need cells with - variable width or height must reimplement cellHeight() and/or - cellWidth(). Use updateTableSize() to tell TQtTableView when the - width or height has changed. - - When you read this documentation, it is important to understand the - distinctions among the four pixel coordinate systems involved. - - \list 1 - \i The \e cell coordinates. (0,0) is the top-left corner of a cell. - Cell coordinates are used by functions such as paintCell(). - - \i The \e table coordinates. (0,0) is the top-left corner of the cell at - row 0 and column 0. These coordinates are absolute; that is, they are - independent of what part of the table is visible at the moment. They are - used by functions such as setXOffset() or maxYOffset(). - - \i The \e widget coordinates. (0,0) is the top-left corner of the widget, - \e including the frame. They are used by functions such as repaint(). - - \i The \e view coordinates. (0,0) is the top-left corner of the view, \e - excluding the frame. This is the least-used coordinate system; it is used by - functions such as viewWidth(). \endlist - - It is rather unfortunate that we have to use four different - coordinate systems, but there was no alternative to provide a flexible and - powerful base class. - - Note: The row,column indices are always given in that order, - i.e., first the vertical (row), then the horizontal (column). This is - the opposite order of all pixel operations, which take first the - horizontal (x) and then the vertical (y). - - <img src=qtablevw-m.png> <img src=qtablevw-w.png> - - \warning the functions setNumRows(), setNumCols(), setCellHeight(), - setCellWidth(), setTableFlags() and clearTableFlags() may cause - virtual functions such as cellWidth() and cellHeight() to be called, - even if autoUpdate() is FALSE. This may cause errors if relevant - state variables are not initialized. - - \warning Experience has shown that use of this widget tends to cause - more bugs than expected and our analysis indicates that the widget's - very flexibility is the problem. If TQScrollView or TQListBox can - easily be made to do the job you need, we recommend subclassing - those widgets rather than TQtTableView. In addition, TQScrollView makes - it easy to have child widgets inside tables, which TQtTableView - doesn't support at all. - - \sa TQScrollView - \link guibooks.html#fowler GUI Design Handbook: Table\endlink -*/ - - -/* - Constructs a table view. The \a parent, \a name and \f arguments - are passed to the TQFrame constructor. - - The \link setTableFlags() table flags\endlink are all cleared (set to 0). - Set \c Tbl_autoVScrollBar or \c Tbl_autoHScrollBar to get automatic scroll - bars and \c Tbl_clipCellPainting to get safe clipping. - - The \link setCellHeight() cell height\endlink and \link setCellWidth() - cell width\endlink are set to 0. - - Frame line shapes (TQFrame::HLink and TQFrame::VLine) are disallowed; - see TQFrame::setFrameStyle(). - - Note that the \a f argument is \e not \link setTableFlags() table - flags \endlink but rather \link TQWidget::TQWidget() widget - flags. \endlink - -*/ - -TQtTableView::TQtTableView( TQWidget *parent, const char *name, WFlags f ) - : TQFrame( parent, name, f ) -{ - nRows = nCols = 0; // zero rows/cols - xCellOffs = yCellOffs = 0; // zero offset - xCellDelta = yCellDelta = 0; // zero cell offset - xOffs = yOffs = 0; // zero total pixel offset - cellH = cellW = 0; // user defined cell size - tFlags = 0; - vScrollBar = hScrollBar = 0; // no scroll bars - cornerSquare = 0; - sbDirty = 0; - eraseInPaint = FALSE; - verSliding = FALSE; - verSnappingOff = FALSE; - horSliding = FALSE; - horSnappingOff = FALSE; - coveringCornerSquare = FALSE; - inSbUpdate = FALSE; -} - -/* - Destroys the table view. -*/ - -TQtTableView::~TQtTableView() -{ - delete vScrollBar; - delete hScrollBar; - delete cornerSquare; -} - - -/* - \internal - Reimplements TQWidget::setBackgroundColor() for binary compatibility. - \sa setPalette() -*/ - -void TQtTableView::setBackgroundColor( const TQColor &c ) -{ - TQWidget::setBackgroundColor( c ); -} - -/*\reimp -*/ - -void TQtTableView::setPalette( const TQPalette &p ) -{ - TQWidget::setPalette( p ); -} - -/*\reimp -*/ - -void TQtTableView::show() -{ - showOrHideScrollBars(); - TQWidget::show(); -} - - -/* - \overload void TQtTableView::repaint( bool erase ) - Repaints the entire view. -*/ - -/* - Repaints the table view directly by calling paintEvent() directly - unless updates are disabled. - - Erases the view area \a (x,y,w,h) if \a erase is TRUE. Parameters \a - (x,y) are in \e widget coordinates. - - If \a w is negative, it is replaced with <code>width() - x</code>. - If \a h is negative, it is replaced with <code>height() - y</code>. - - Doing a repaint() usually is faster than doing an update(), but - calling update() many times in a row will generate a single paint - event. - - At present, TQtTableView is the only widget that reimplements \link - TQWidget::repaint() repaint()\endlink. It does this because by - clearing and then repainting one cell at at time, it can make the - screen flicker less than it would otherwise. */ - -void TQtTableView::repaint( int x, int y, int w, int h, bool erase ) -{ - if ( !isVisible() || testWState(WState_BlockUpdates) ) - return; - if ( w < 0 ) - w = width() - x; - if ( h < 0 ) - h = height() - y; - TQRect r( x, y, w, h ); - if ( r.isEmpty() ) - return; // nothing to do - TQPaintEvent e( r ); - if ( erase && backgroundMode() != NoBackground ) - eraseInPaint = TRUE; // erase when painting - paintEvent( &e ); - eraseInPaint = FALSE; -} - -/* - \overload void TQtTableView::repaint( const TQRect &r, bool erase ) - Replaints rectangle \a r. If \a erase is TRUE draws the background - using the palette's background. -*/ - - -/* - \fn int TQtTableView::numRows() const - Returns the number of rows in the table. - \sa numCols(), setNumRows() -*/ - -/* - Sets the number of rows of the table to \a rows (must be non-negative). - Does not change topCell(). - - The table repaints itself automatically if autoUpdate() is set. - - \sa numCols(), setNumCols(), numRows() -*/ - -void TQtTableView::setNumRows( int rows ) -{ - if ( rows < 0 ) { -#if defined(QT_CHECK_RANGE) - tqWarning( "TQtTableView::setNumRows: (%s) Negative argument %d.", - name( "unnamed" ), rows ); -#endif - return; - } - if ( nRows == rows ) - return; - - if ( autoUpdate() && isVisible() ) { - int oldLastVisible = lastRowVisible(); - int oldTopCell = topCell(); - nRows = rows; - if ( autoUpdate() && isVisible() && - ( oldLastVisible != lastRowVisible() || oldTopCell != topCell() ) ) - repaint( oldTopCell != topCell() ); - } else { - // Be more careful - if destructing, bad things might happen. - nRows = rows; - } - updateScrollBars( verRange ); - updateFrameSize(); -} - -/* - \fn int TQtTableView::numCols() const - Returns the number of columns in the table. - \sa numRows(), setNumCols() -*/ - -/* - Sets the number of columns of the table to \a cols (must be non-negative). - Does not change leftCell(). - - The table repaints itself automatically if autoUpdate() is set. - - \sa numCols(), numRows(), setNumRows() -*/ - -void TQtTableView::setNumCols( int cols ) -{ - if ( cols < 0 ) { -#if defined(QT_CHECK_RANGE) - tqWarning( "TQtTableView::setNumCols: (%s) Negative argument %d.", - name( "unnamed" ), cols ); -#endif - return; - } - if ( nCols == cols ) - return; - int oldCols = nCols; - nCols = cols; - if ( autoUpdate() && isVisible() ) { - int maxCol = lastColVisible(); - if ( maxCol >= oldCols || maxCol >= nCols ) - repaint(); - } - updateScrollBars( horRange ); - updateFrameSize(); -} - - -/* - \fn int TQtTableView::topCell() const - Returns the index of the first row in the table that is visible in - the view. The index of the first row is 0. - \sa leftCell(), setTopCell() -*/ - -/* - Scrolls the table so that \a row becomes the top row. - The index of the very first row is 0. - \sa setYOffset(), setTopLeftCell(), setLeftCell() -*/ - -void TQtTableView::setTopCell( int row ) -{ - setTopLeftCell( row, -1 ); - return; -} - -/* - \fn int TQtTableView::leftCell() const - Returns the index of the first column in the table that is visible in - the view. The index of the very leftmost column is 0. - \sa topCell(), setLeftCell() -*/ - -/* - Scrolls the table so that \a col becomes the leftmost - column. The index of the leftmost column is 0. - \sa setXOffset(), setTopLeftCell(), setTopCell() -*/ - -void TQtTableView::setLeftCell( int col ) -{ - setTopLeftCell( -1, col ); - return; -} - -/* - Scrolls the table so that the cell at row \a row and colum \a - col becomes the top-left cell in the view. The cell at the extreme - top left of the table is at position (0,0). - \sa setLeftCell(), setTopCell(), setOffset() -*/ - -void TQtTableView::setTopLeftCell( int row, int col ) -{ - int newX = xOffs; - int newY = yOffs; - - if ( col >= 0 ) { - if ( cellW ) { - newX = col*cellW; - if ( newX > maxXOffset() ) - newX = maxXOffset(); - } else { - newX = 0; - while ( col ) - newX += cellWidth( --col ); // optimize using current! ### - } - } - if ( row >= 0 ) { - if ( cellH ) { - newY = row*cellH; - if ( newY > maxYOffset() ) - newY = maxYOffset(); - } else { - newY = 0; - while ( row ) - newY += cellHeight( --row ); // optimize using current! ### - } - } - setOffset( newX, newY ); -} - - -/* - \fn int TQtTableView::xOffset() const - - Returns the x coordinate in \e table coordinates of the pixel that is - currently on the left edge of the view. - - \sa setXOffset(), yOffset(), leftCell() */ - -/* - Scrolls the table so that \a x becomes the leftmost pixel in the view. - The \a x parameter is in \e table coordinates. - - The interaction with \link setTableFlags() Tbl_snapToHGrid - \endlink is tricky. - - \sa xOffset(), setYOffset(), setOffset(), setLeftCell() -*/ - -void TQtTableView::setXOffset( int x ) -{ - setOffset( x, yOffset() ); -} - -/* - \fn int TQtTableView::yOffset() const - - Returns the y coordinate in \e table coordinates of the pixel that is - currently on the top edge of the view. - - \sa setYOffset(), xOffset(), topCell() -*/ - - -/* - Scrolls the table so that \a y becomes the top pixel in the view. - The \a y parameter is in \e table coordinates. - - The interaction with \link setTableFlags() Tbl_snapToVGrid - \endlink is tricky. - - \sa yOffset(), setXOffset(), setOffset(), setTopCell() -*/ - -void TQtTableView::setYOffset( int y ) -{ - setOffset( xOffset(), y ); -} - -/* - Scrolls the table so that \a (x,y) becomes the top-left pixel - in the view. Parameters \a (x,y) are in \e table coordinates. - - The interaction with \link setTableFlags() Tbl_snapTo*Grid \endlink - is tricky. If \a updateScrBars is TRUE, the scroll bars are - updated. - - \sa xOffset(), yOffset(), setXOffset(), setYOffset(), setTopLeftCell() -*/ - -void TQtTableView::setOffset( int x, int y, bool updateScrBars ) -{ - if ( (!testTableFlags(Tbl_snapToHGrid) || xCellDelta == 0) && - (!testTableFlags(Tbl_snapToVGrid) || yCellDelta == 0) && - (x == xOffs && y == yOffs) ) - return; - - if ( x < 0 ) - x = 0; - if ( y < 0 ) - y = 0; - - if ( cellW ) { - if ( x > maxXOffset() ) - x = maxXOffset(); - xCellOffs = x / cellW; - if ( !testTableFlags(Tbl_snapToHGrid) ) { - xCellDelta = (short)(x % cellW); - } else { - x = xCellOffs*cellW; - xCellDelta = 0; - } - } else { - int xn=0, xcd=0, col = 0; - while ( col < nCols-1 && x >= xn+(xcd=cellWidth(col)) ) { - xn += xcd; - col++; - } - xCellOffs = col; - if ( testTableFlags(Tbl_snapToHGrid) ) { - xCellDelta = 0; - x = xn; - } else { - xCellDelta = (short)(x-xn); - } - } - if ( cellH ) { - if ( y > maxYOffset() ) - y = maxYOffset(); - yCellOffs = y / cellH; - if ( !testTableFlags(Tbl_snapToVGrid) ) { - yCellDelta = (short)(y % cellH); - } else { - y = yCellOffs*cellH; - yCellDelta = 0; - } - } else { - int yn=0, yrd=0, row=0; - while ( row < nRows-1 && y >= yn+(yrd=cellHeight(row)) ) { - yn += yrd; - row++; - } - yCellOffs = row; - if ( testTableFlags(Tbl_snapToVGrid) ) { - yCellDelta = 0; - y = yn; - } else { - yCellDelta = (short)(y-yn); - } - } - int dx = (x - xOffs); - int dy = (y - yOffs); - xOffs = x; - yOffs = y; - if ( autoUpdate() && isVisible() ) - scroll( dx, dy ); - if ( updateScrBars ) - updateScrollBars( verValue | horValue ); -} - - -/* - \overload int TQtTableView::cellWidth() const - - Returns the column width in pixels. Returns 0 if the columns have - variable widths. - - \sa setCellWidth(), cellHeight() -*/ - -/* - Returns the width of column \a col in pixels. - - This function is virtual and must be reimplemented by subclasses that - have variable cell widths. Note that if the total table width - changes, updateTableSize() must be called. - - \sa setCellWidth(), cellHeight(), totalWidth(), updateTableSize() -*/ - -int TQtTableView::cellWidth( int ) -{ - return cellW; -} - - -/* - Sets the width in pixels of the table cells to \a cellWidth. - - Setting it to 0 means that the column width is variable. When - set to 0 (this is the default) TQtTableView calls the virtual function - cellWidth() to get the width. - - \sa cellWidth(), setCellHeight(), totalWidth(), numCols() -*/ - -void TQtTableView::setCellWidth( int cellWidth ) -{ - if ( cellW == cellWidth ) - return; -#if defined(QT_CHECK_RANGE) - if ( cellWidth < 0 || cellWidth > SHRT_MAX ) { - tqWarning( "TQtTableView::setCellWidth: (%s) Argument out of range (%d)", - name( "unnamed" ), cellWidth ); - return; - } -#endif - cellW = (short)cellWidth; - - updateScrollBars( horSteps | horRange ); - if ( autoUpdate() && isVisible() ) - repaint(); - -} - -/* - \overload int TQtTableView::cellHeight() const - - Returns the row height, in pixels. Returns 0 if the rows have - variable heights. - - \sa setCellHeight(), cellWidth() -*/ - - -/* - Returns the height of row \a row in pixels. - - This function is virtual and must be reimplemented by subclasses that - have variable cell heights. Note that if the total table height - changes, updateTableSize() must be called. - - \sa setCellHeight(), cellWidth(), totalHeight() -*/ - -int TQtTableView::cellHeight( int ) -{ - return cellH; -} - -/* - Sets the height in pixels of the table cells to \a cellHeight. - - Setting it to 0 means that the row height is variable. When set - to 0 (this is the default), TQtTableView calls the virtual function - cellHeight() to get the height. - - \sa cellHeight(), setCellWidth(), totalHeight(), numRows() -*/ - -void TQtTableView::setCellHeight( int cellHeight ) -{ - if ( cellH == cellHeight ) - return; -#if defined(QT_CHECK_RANGE) - if ( cellHeight < 0 || cellHeight > SHRT_MAX ) { - tqWarning( "TQtTableView::setCellHeight: (%s) Argument out of range (%d)", - name( "unnamed" ), cellHeight ); - return; - } -#endif - cellH = (short)cellHeight; - if ( autoUpdate() && isVisible() ) - repaint(); - updateScrollBars( verSteps | verRange ); -} - - -/* - Returns the total width of the table in pixels. - - This function is virtual and should be reimplemented by subclasses that - have variable cell widths and a non-trivial cellWidth() function, or a - large number of columns in the table. - - The default implementation may be slow for very wide tables. - - \sa cellWidth(), totalHeight() */ - -int TQtTableView::totalWidth() -{ - if ( cellW ) { - return cellW*nCols; - } else { - int tw = 0; - for( int i = 0 ; i < nCols ; i++ ) - tw += cellWidth( i ); - return tw; - } -} - -/* - Returns the total height of the table in pixels. - - This function is virtual and should be reimplemented by subclasses that - have variable cell heights and a non-trivial cellHeight() function, or a - large number of rows in the table. - - The default implementation may be slow for very tall tables. - - \sa cellHeight(), totalWidth() -*/ - -int TQtTableView::totalHeight() -{ - if ( cellH ) { - return cellH*nRows; - } else { - int th = 0; - for( int i = 0 ; i < nRows ; i++ ) - th += cellHeight( i ); - return th; - } -} - - -/* - \fn uint TQtTableView::tableFlags() const - - Returns the union of the table flags that are currently set. - - \sa setTableFlags(), clearTableFlags(), testTableFlags() -*/ - -/* - \fn bool TQtTableView::testTableFlags( uint f ) const - - Returns TRUE if any of the table flags in \a f are currently set, - otherwise FALSE. - - \sa setTableFlags(), clearTableFlags(), tableFlags() -*/ - -/* - Sets the table flags to \a f. - - If a flag setting changes the appearance of the table, the table is - repainted if - and only if - autoUpdate() is TRUE. - - The table flags are mostly single bits, though there are some multibit - flags for convenience. Here is a complete list: - - <dl compact> - <dt> Tbl_vScrollBar <dd> - The table has a vertical scroll bar. - <dt> Tbl_hScrollBar <dd> - The table has a horizontal scroll bar. - <dt> Tbl_autoVScrollBar <dd> - The table has a vertical scroll bar if - - and only if - the table is taller than the view. - <dt> Tbl_autoHScrollBar <dd> The table has a horizontal scroll bar if - - and only if - the table is wider than the view. - <dt> Tbl_autoScrollBars <dd> - The union of the previous two flags. - <dt> Tbl_clipCellPainting <dd> - The table uses TQPainter::setClipRect() to - make sure that paintCell() will not draw outside the cell - boundaries. - <dt> Tbl_cutCellsV <dd> - The table will never show part of a - cell at the bottom of the table; if there is not space for all of - a cell, the space is left blank. - <dt> Tbl_cutCellsH <dd> - The table will never show part of a - cell at the right side of the table; if there is not space for all of - a cell, the space is left blank. - <dt> Tbl_cutCells <dd> - The union of the previous two flags. - <dt> Tbl_scrollLastHCell <dd> - When the user scrolls horizontally, - let him/her scroll the last cell left until it is at the left - edge of the view. If this flag is not set, the user can only scroll - to the point where the last cell is completely visible. - <dt> Tbl_scrollLastVCell <dd> - When the user scrolls vertically, let - him/her scroll the last cell up until it is at the top edge of - the view. If this flag is not set, the user can only scroll to the - point where the last cell is completely visible. - <dt> Tbl_scrollLastCell <dd> - The union of the previous two flags. - <dt> Tbl_smoothHScrolling <dd> - The table scrolls as smoothly as - possible when the user scrolls horizontally. When this flag is not - set, scrolling is done one cell at a time. - <dt> Tbl_smoothVScrolling <dd> - The table scrolls as smoothly as - possible when scrolling vertically. When this flag is not set, - scrolling is done one cell at a time. - <dt> Tbl_smoothScrolling <dd> - The union of the previous two flags. - <dt> Tbl_snapToHGrid <dd> - Except when the user is actually scrolling, - the leftmost column shown snaps to the leftmost edge of the view. - <dt> Tbl_snapToVGrid <dd> - Except when the user is actually - scrolling, the top row snaps to the top edge of the view. - <dt> Tbl_snapToGrid <dd> - The union of the previous two flags. - </dl> - - You can specify more than one flag at a time using bitwise OR. - - Example: - \code - setTableFlags( Tbl_smoothScrolling | Tbl_autoScrollBars ); - \endcode - - \warning The cutCells options (\c Tbl_cutCells, \c Tbl_cutCellsH and - Tbl_cutCellsV) may cause painting problems when scrollbars are - enabled. Do not combine cutCells and scrollbars. - - - \sa clearTableFlags(), testTableFlags(), tableFlags() -*/ - -void TQtTableView::setTableFlags( uint f ) -{ - f = (f ^ tFlags) & f; // clear flags already set - tFlags |= f; - - bool updateOn = autoUpdate(); - setAutoUpdate( FALSE ); - - uint repaintMask = Tbl_cutCellsV | Tbl_cutCellsH; - - if ( f & Tbl_vScrollBar ) { - setVerScrollBar( TRUE ); - } - if ( f & Tbl_hScrollBar ) { - setHorScrollBar( TRUE ); - } - if ( f & Tbl_autoVScrollBar ) { - updateScrollBars( verRange ); - } - if ( f & Tbl_autoHScrollBar ) { - updateScrollBars( horRange ); - } - if ( f & Tbl_scrollLastHCell ) { - updateScrollBars( horRange ); - } - if ( f & Tbl_scrollLastVCell ) { - updateScrollBars( verRange ); - } - if ( f & Tbl_snapToHGrid ) { - updateScrollBars( horRange ); - } - if ( f & Tbl_snapToVGrid ) { - updateScrollBars( verRange ); - } - if ( f & Tbl_snapToGrid ) { // Note: checks for 2 flags - if ( (f & Tbl_snapToHGrid) != 0 && xCellDelta != 0 || //have to scroll? - (f & Tbl_snapToVGrid) != 0 && yCellDelta != 0 ) { - snapToGrid( (f & Tbl_snapToHGrid) != 0, // do snapping - (f & Tbl_snapToVGrid) != 0 ); - repaintMask |= Tbl_snapToGrid; // repaint table - } - } - - if ( updateOn ) { - setAutoUpdate( TRUE ); - updateScrollBars(); - if ( isVisible() && (f & repaintMask) ) - repaint(); - } - -} - -/* - Clears the \link setTableFlags() table flags\endlink that are set - in \a f. - - Example (clears a single flag): - \code - clearTableFlags( Tbl_snapToGrid ); - \endcode - - The default argument clears all flags. - - \sa setTableFlags(), testTableFlags(), tableFlags() -*/ - -void TQtTableView::clearTableFlags( uint f ) -{ - f = (f ^ ~tFlags) & f; // clear flags that are already 0 - tFlags &= ~f; - - bool updateOn = autoUpdate(); - setAutoUpdate( FALSE ); - - uint repaintMask = Tbl_cutCellsV | Tbl_cutCellsH; - - if ( f & Tbl_vScrollBar ) { - setVerScrollBar( FALSE ); - } - if ( f & Tbl_hScrollBar ) { - setHorScrollBar( FALSE ); - } - if ( f & Tbl_scrollLastHCell ) { - int maxX = maxXOffset(); - if ( xOffs > maxX ) { - setOffset( maxX, yOffs ); - repaintMask |= Tbl_scrollLastHCell; - } - updateScrollBars( horRange ); - } - if ( f & Tbl_scrollLastVCell ) { - int maxY = maxYOffset(); - if ( yOffs > maxY ) { - setOffset( xOffs, maxY ); - repaintMask |= Tbl_scrollLastVCell; - } - updateScrollBars( verRange ); - } - if ( f & Tbl_smoothScrolling ) { // Note: checks for 2 flags - if ((f & Tbl_smoothHScrolling) != 0 && xCellDelta != 0 ||//must scroll? - (f & Tbl_smoothVScrolling) != 0 && yCellDelta != 0 ) { - snapToGrid( (f & Tbl_smoothHScrolling) != 0, // do snapping - (f & Tbl_smoothVScrolling) != 0 ); - repaintMask |= Tbl_smoothScrolling; // repaint table - } - } - if ( f & Tbl_snapToHGrid ) { - updateScrollBars( horRange ); - } - if ( f & Tbl_snapToVGrid ) { - updateScrollBars( verRange ); - } - if ( updateOn ) { - setAutoUpdate( TRUE ); - updateScrollBars(); // returns immediately if nothing to do - if ( isVisible() && (f & repaintMask) ) - repaint(); - } - -} - - -/* - \fn bool TQtTableView::autoUpdate() const - - Returns TRUE if the view updates itself automatically whenever it - is changed in some way. - - \sa setAutoUpdate() -*/ - -/* - Sets the auto-update option of the table view to \a enable. - - If \a enable is TRUE (this is the default), the view updates itself - automatically whenever it has changed in some way (for example, when a - \link setTableFlags() flag\endlink is changed). - - If \a enable is FALSE, the view does NOT repaint itself or update - its internal state variables when it is changed. This can be - useful to avoid flicker during large changes and is singularly - useless otherwise. Disable auto-update, do the changes, re-enable - auto-update and call repaint(). - - \warning Do not leave the view in this state for a long time - (i.e., between events). If, for example, the user interacts with the - view when auto-update is off, strange things can happen. - - Setting auto-update to TRUE does not repaint the view; you must call - repaint() to do this. - - \sa autoUpdate(), repaint() -*/ - -void TQtTableView::setAutoUpdate( bool enable ) -{ - if ( isUpdatesEnabled() == enable ) - return; - setUpdatesEnabled( enable ); - if ( enable ) { - showOrHideScrollBars(); - updateScrollBars(); - } -} - - -/* - Repaints the cell at row \a row, column \a col if it is inside the view. - - If \a erase is TRUE, the relevant part of the view is cleared to the - background color/pixmap before the contents are repainted. - - \sa isVisible() -*/ - -void TQtTableView::updateCell( int row, int col, bool erase ) -{ - int xPos, yPos; - if ( !colXPos( col, &xPos ) ) - return; - if ( !rowYPos( row, &yPos ) ) - return; - TQRect uR = TQRect( xPos, yPos, - cellW ? cellW : cellWidth(col), - cellH ? cellH : cellHeight(row) ); - repaint( uR.intersect(viewRect()), erase ); -} - - -/* - \fn TQRect TQtTableView::cellUpdateRect() const - - This function should be called only from the paintCell() function in - subclasses. It returns the portion of a cell that actually needs to be - updated in \e cell coordinates. This is useful only for non-trivial - paintCell(). - -*/ - -/* - Returns the rectangle that is the actual table, excluding any - frame, in \e widget coordinates. -*/ - -TQRect TQtTableView::viewRect() const -{ - return TQRect( frameWidth(), frameWidth(), viewWidth(), viewHeight() ); -} - - -/* - Returns the index of the last (bottom) row in the view. - The index of the first row is 0. - - If no rows are visible it returns -1. This can happen if the - view is too small for the first row and Tbl_cutCellsV is set. - - \sa lastColVisible() -*/ - -int TQtTableView::lastRowVisible() const -{ - int cellMaxY; - int row = findRawRow( maxViewY(), &cellMaxY ); - if ( row == -1 || row >= nRows ) { // maxViewY() past end? - row = nRows - 1; // yes: return last row - } else { - if ( testTableFlags(Tbl_cutCellsV) && cellMaxY > maxViewY() ) { - if ( row == yCellOffs ) // cut by right margin? - return -1; // yes, nothing in the view - else - row = row - 1; // cut by margin, one back - } - } - return row; -} - -/* - Returns the index of the last (right) column in the view. - The index of the first column is 0. - - If no columns are visible it returns -1. This can happen if the - view is too narrow for the first column and Tbl_cutCellsH is set. - - \sa lastRowVisible() -*/ - -int TQtTableView::lastColVisible() const -{ - int cellMaxX; - int col = findRawCol( maxViewX(), &cellMaxX ); - if ( col == -1 || col >= nCols ) { // maxViewX() past end? - col = nCols - 1; // yes: return last col - } else { - if ( testTableFlags(Tbl_cutCellsH) && cellMaxX > maxViewX() ) { - if ( col == xCellOffs ) // cut by bottom margin? - return -1; // yes, nothing in the view - else - col = col - 1; // cell by margin, one back - } - } - return col; -} - -/* - Returns TRUE if \a row is at least partially visible. - \sa colIsVisible() -*/ - -bool TQtTableView::rowIsVisible( int row ) const -{ - return rowYPos( row, 0 ); -} - -/* - Returns TRUE if \a col is at least partially visible. - \sa rowIsVisible() -*/ - -bool TQtTableView::colIsVisible( int col ) const -{ - return colXPos( col, 0 ); -} - - -/* - \internal - Called when both scroll bars are active at the same time. Covers the - bottom left corner between the two scroll bars with an empty widget. -*/ - -void TQtTableView::coverCornerSquare( bool enable ) -{ - coveringCornerSquare = enable; - if ( !cornerSquare && enable ) { - cornerSquare = new TQCornerSquare( this ); - TQ_CHECK_PTR( cornerSquare ); - cornerSquare->setGeometry( maxViewX() + frameWidth() + 1, - maxViewY() + frameWidth() + 1, - VSBEXT, - HSBEXT); - } - if ( autoUpdate() && cornerSquare ) { - if ( enable ) - cornerSquare->show(); - else - cornerSquare->hide(); - } -} - - -/* - \internal - Scroll the view to a position such that: - - If \a horizontal is TRUE, the leftmost column shown fits snugly - with the left edge of the view. - - If \a vertical is TRUE, the top row shown fits snugly with the top - of the view. - - You can achieve the same effect automatically by setting any of the - \link setTableFlags() Tbl_snapTo*Grid \endlink table flags. -*/ - -void TQtTableView::snapToGrid( bool horizontal, bool vertical ) -{ - int newXCell = -1; - int newYCell = -1; - if ( horizontal && xCellDelta != 0 ) { - int w = cellW ? cellW : cellWidth( xCellOffs ); - if ( xCellDelta >= w/2 ) - newXCell = xCellOffs + 1; - else - newXCell = xCellOffs; - } - if ( vertical && yCellDelta != 0 ) { - int h = cellH ? cellH : cellHeight( yCellOffs ); - if ( yCellDelta >= h/2 ) - newYCell = yCellOffs + 1; - else - newYCell = yCellOffs; - } - setTopLeftCell( newYCell, newXCell ); //row,column -} - -/* - \internal - This internal slot is connected to the horizontal scroll bar's - TQScrollBar::valueChanged() signal. - - Moves the table horizontally to offset \a val without updating the - scroll bar. -*/ - -void TQtTableView::horSbValue( int val ) -{ - if ( horSliding ) { - horSliding = FALSE; - if ( horSnappingOff ) { - horSnappingOff = FALSE; - tFlags |= Tbl_snapToHGrid; - } - } - setOffset( val, yOffs, FALSE ); -} - -/* - \internal - This internal slot is connected to the horizontal scroll bar's - TQScrollBar::sliderMoved() signal. - - Scrolls the table smoothly horizontally even if \c Tbl_snapToHGrid is set. -*/ - -void TQtTableView::horSbSliding( int val ) -{ - if ( testTableFlags(Tbl_snapToHGrid) && - testTableFlags(Tbl_smoothHScrolling) ) { - tFlags &= ~Tbl_snapToHGrid; // turn off snapping while sliding - setOffset( val, yOffs, FALSE ); - tFlags |= Tbl_snapToHGrid; // turn on snapping again - } else { - setOffset( val, yOffs, FALSE ); - } -} - -/* - \internal - This internal slot is connected to the horizontal scroll bar's - TQScrollBar::sliderReleased() signal. -*/ - -void TQtTableView::horSbSlidingDone( ) -{ - if ( testTableFlags(Tbl_snapToHGrid) && - testTableFlags(Tbl_smoothHScrolling) ) - snapToGrid( TRUE, FALSE ); -} - -/* - \internal - This internal slot is connected to the vertical scroll bar's - TQScrollBar::valueChanged() signal. - - Moves the table vertically to offset \a val without updating the - scroll bar. -*/ - -void TQtTableView::verSbValue( int val ) -{ - if ( verSliding ) { - verSliding = FALSE; - if ( verSnappingOff ) { - verSnappingOff = FALSE; - tFlags |= Tbl_snapToVGrid; - } - } - setOffset( xOffs, val, FALSE ); -} - -/* - \internal - This internal slot is connected to the vertical scroll bar's - TQScrollBar::sliderMoved() signal. - - Scrolls the table smoothly vertically even if \c Tbl_snapToVGrid is set. -*/ - -void TQtTableView::verSbSliding( int val ) -{ - if ( testTableFlags(Tbl_snapToVGrid) && - testTableFlags(Tbl_smoothVScrolling) ) { - tFlags &= ~Tbl_snapToVGrid; // turn off snapping while sliding - setOffset( xOffs, val, FALSE ); - tFlags |= Tbl_snapToVGrid; // turn on snapping again - } else { - setOffset( xOffs, val, FALSE ); - } -} - -/* - \internal - This internal slot is connected to the vertical scroll bar's - TQScrollBar::sliderReleased() signal. -*/ - -void TQtTableView::verSbSlidingDone( ) -{ - if ( testTableFlags(Tbl_snapToVGrid) && - testTableFlags(Tbl_smoothVScrolling) ) - snapToGrid( FALSE, TRUE ); -} - - -/* - This virtual function is called before painting of table cells - is started. It can be reimplemented by subclasses that want to - to set up the painter in a special way and that do not want to - do so for each cell. -*/ - -void TQtTableView::setupPainter( TQPainter * ) -{ -} - -/* - \fn void TQtTableView::paintCell( TQPainter *p, int row, int col ) - - This pure virtual function is called to paint the single cell at \a - (row,col) using \a p, which is open when paintCell() is called and - must remain open. - - The coordinate system is \link TQPainter::translate() translated \endlink - so that the origin is at the top-left corner of the cell to be - painted, i.e. \e cell coordinates. Do not scale or shear the coordinate - system (or if you do, restore the transformation matrix before you - return). - - The painter is not clipped by default and for maximum efficiency. For safety, - call setTableFlags(Tbl_clipCellPainting) to enable clipping. - - \sa paintEvent(), setTableFlags() */ - - -/* - Handles paint events, \a e, for the table view. - - Calls paintCell() for the cells that needs to be repainted. -*/ - -void TQtTableView::paintEvent( TQPaintEvent *e ) -{ - TQRect updateR = e->rect(); // update rectangle - if ( sbDirty ) { - bool e = eraseInPaint; - updateScrollBars(); - eraseInPaint = e; - } - - TQPainter paint( this ); - - if ( !contentsRect().contains( updateR, TRUE ) ) {// update frame ? - drawFrame( &paint ); - if ( updateR.left() < frameWidth() ) //### - updateR.setLeft( frameWidth() ); - if ( updateR.top() < frameWidth() ) - updateR.setTop( frameWidth() ); - } - - int maxWX = maxViewX(); - int maxWY = maxViewY(); - if ( updateR.right() > maxWX ) - updateR.setRight( maxWX ); - if ( updateR.bottom() > maxWY ) - updateR.setBottom( maxWY ); - - setupPainter( &paint ); // prepare for painting table - - int firstRow = findRow( updateR.y() ); - int firstCol = findCol( updateR.x() ); - int xStart, yStart; - if ( !colXPos( firstCol, &xStart ) || !rowYPos( firstRow, &yStart ) ) { - paint.eraseRect( updateR ); // erase area outside cells but in view - return; - } - int maxX = updateR.right(); - int maxY = updateR.bottom(); - int row = firstRow; - int col; - int yPos = yStart; - int xPos = maxX+1; // in case the while() is empty - int nextX; - int nextY; - TQRect winR = viewRect(); - TQRect cellR; - TQRect cellUR; -#ifndef TQT_NO_TRANSFORMATIONS - TQWMatrix matrix; -#endif - - while ( yPos <= maxY && row < nRows ) { - nextY = yPos + (cellH ? cellH : cellHeight( row )); - if ( testTableFlags( Tbl_cutCellsV ) && nextY > ( maxWY + 1 ) ) - break; - col = firstCol; - xPos = xStart; - while ( xPos <= maxX && col < nCols ) { - nextX = xPos + (cellW ? cellW : cellWidth( col )); - if ( testTableFlags( Tbl_cutCellsH ) && nextX > ( maxWX + 1 ) ) - break; - - cellR.setRect( xPos, yPos, cellW ? cellW : cellWidth(col), - cellH ? cellH : cellHeight(row) ); - cellUR = cellR.intersect( updateR ); - if ( cellUR.isValid() ) { - cellUpdateR = cellUR; - cellUpdateR.moveBy( -xPos, -yPos ); // cell coordinates - if ( eraseInPaint ) - paint.eraseRect( cellUR ); - -#ifndef TQT_NO_TRANSFORMATIONS - matrix.translate( xPos, yPos ); - paint.setWorldMatrix( matrix ); - if ( testTableFlags(Tbl_clipCellPainting) || - frameWidth() > 0 && !winR.contains( cellR ) ) { //##arnt - paint.setClipRect( cellUR ); - paintCell( &paint, row, col ); - paint.setClipping( FALSE ); - } else { - paintCell( &paint, row, col ); - } - matrix.reset(); - paint.setWorldMatrix( matrix ); -#else - paint.translate( xPos, yPos ); - if ( testTableFlags(Tbl_clipCellPainting) || - frameWidth() > 0 && !winR.contains( cellR ) ) { //##arnt - paint.setClipRect( cellUR ); - paintCell( &paint, row, col ); - paint.setClipping( FALSE ); - } else { - paintCell( &paint, row, col ); - } - paint.translate( -xPos, -yPos ); -#endif - } - col++; - xPos = nextX; - } - row++; - yPos = nextY; - } - - // while painting we have to erase any areas in the view that - // are not covered by cells but are covered by the paint event - // rectangle these must be erased. We know that xPos is the last - // x pixel updated + 1 and that yPos is the last y pixel updated + 1. - - // Note that this needs to be done regardless whether we do - // eraseInPaint or not. Reason: a subclass may implement - // flicker-freeness and encourage the use of repaint(FALSE). - // The subclass, however, cannot draw all pixels, just those - // inside the cells. So TQtTableView is reponsible for all pixels - // outside the cells. - - TQRect viewR = viewRect(); - const TQColorGroup g = colorGroup(); - - if ( xPos <= maxX ) { - TQRect r = viewR; - r.setLeft( xPos ); - r.setBottom( yPos<maxY?yPos:maxY ); - if ( inherits( "TQMultiLineEdit" ) ) - paint.fillRect( r.intersect( updateR ), g.base() ); - else - paint.eraseRect( r.intersect( updateR ) ); - } - if ( yPos <= maxY ) { - TQRect r = viewR; - r.setTop( yPos ); - if ( inherits( "TQMultiLineEdit" ) ) - paint.fillRect( r.intersect( updateR ), g.base() ); - else - paint.eraseRect( r.intersect( updateR ) ); - } -} - -/*\reimp -*/ -void TQtTableView::resizeEvent( TQResizeEvent * ) -{ - updateScrollBars( horValue | verValue | horSteps | horGeometry | horRange | - verSteps | verGeometry | verRange ); - showOrHideScrollBars(); - updateFrameSize(); - int maxX = TQMIN( xOffs, maxXOffset() ); // ### can be slow - int maxY = TQMIN( yOffs, maxYOffset() ); - setOffset( maxX, maxY ); -} - - -/* - Redraws all visible cells in the table view. -*/ - -void TQtTableView::updateView() -{ - repaint( viewRect() ); -} - -/* - Returns a pointer to the vertical scroll bar mainly so you can - connect() to its signals. Note that the scroll bar works in pixel - values; use findRow() to translate to cell numbers. -*/ - -TQScrollBar *TQtTableView::verticalScrollBar() const -{ - TQtTableView *that = (TQtTableView*)this; // semantic const - if ( !vScrollBar ) { - TQScrollBar *sb = new TQScrollBar( TQScrollBar::Vertical, that ); -#ifndef TQT_NO_CURSOR - sb->setCursor( arrowCursor ); -#endif - sb->resize( sb->sizeHint() ); // height is irrelevant - TQ_CHECK_PTR(sb); - sb->setTracking( FALSE ); - sb->setFocusPolicy( NoFocus ); - connect( sb, SIGNAL(valueChanged(int)), - SLOT(verSbValue(int))); - connect( sb, SIGNAL(sliderMoved(int)), - SLOT(verSbSliding(int))); - connect( sb, SIGNAL(sliderReleased()), - SLOT(verSbSlidingDone())); - sb->hide(); - that->vScrollBar = sb; - return sb; - } - return vScrollBar; -} - -/* - Returns a pointer to the horizontal scroll bar mainly so you can - connect() to its signals. Note that the scroll bar works in pixel - values; use findCol() to translate to cell numbers. -*/ - -TQScrollBar *TQtTableView::horizontalScrollBar() const -{ - TQtTableView *that = (TQtTableView*)this; // semantic const - if ( !hScrollBar ) { - TQScrollBar *sb = new TQScrollBar( TQScrollBar::Horizontal, that ); -#ifndef TQT_NO_CURSOR - sb->setCursor( arrowCursor ); -#endif - sb->resize( sb->sizeHint() ); // width is irrelevant - sb->setFocusPolicy( NoFocus ); - TQ_CHECK_PTR(sb); - sb->setTracking( FALSE ); - connect( sb, SIGNAL(valueChanged(int)), - SLOT(horSbValue(int))); - connect( sb, SIGNAL(sliderMoved(int)), - SLOT(horSbSliding(int))); - connect( sb, SIGNAL(sliderReleased()), - SLOT(horSbSlidingDone())); - sb->hide(); - that->hScrollBar = sb; - return sb; - } - return hScrollBar; -} - -/* - Enables or disables the horizontal scroll bar, as required by - setAutoUpdate() and the \link setTableFlags() table flags\endlink. -*/ - -void TQtTableView::setHorScrollBar( bool on, bool update ) -{ - if ( on ) { - tFlags |= Tbl_hScrollBar; - horizontalScrollBar(); // created - if ( update ) - updateScrollBars( horMask | verMask ); - else - sbDirty = sbDirty | (horMask | verMask); - if ( testTableFlags( Tbl_vScrollBar ) ) - coverCornerSquare( TRUE ); - if ( autoUpdate() ) - sbDirty = sbDirty | horMask; - } else { - tFlags &= ~Tbl_hScrollBar; - if ( !hScrollBar ) - return; - coverCornerSquare( FALSE ); - bool hideScrollBar = autoUpdate() && hScrollBar->isVisible(); - if ( hideScrollBar ) - hScrollBar->hide(); - if ( update ) - updateScrollBars( verMask ); - else - sbDirty = sbDirty | verMask; - if ( hideScrollBar && isVisible() ) - repaint( hScrollBar->x(), hScrollBar->y(), - width() - hScrollBar->x(), hScrollBar->height() ); - } - if ( update ) - updateFrameSize(); -} - - -/* - Enables or disables the vertical scroll bar, as required by - setAutoUpdate() and the \link setTableFlags() table flags\endlink. -*/ - -void TQtTableView::setVerScrollBar( bool on, bool update ) -{ - if ( on ) { - tFlags |= Tbl_vScrollBar; - verticalScrollBar(); // created - if ( update ) - updateScrollBars( verMask | horMask ); - else - sbDirty = sbDirty | (horMask | verMask); - if ( testTableFlags( Tbl_hScrollBar ) ) - coverCornerSquare( TRUE ); - if ( autoUpdate() ) - sbDirty = sbDirty | verMask; - } else { - tFlags &= ~Tbl_vScrollBar; - if ( !vScrollBar ) - return; - coverCornerSquare( FALSE ); - bool hideScrollBar = autoUpdate() && vScrollBar->isVisible(); - if ( hideScrollBar ) - vScrollBar->hide(); - if ( update ) - updateScrollBars( horMask ); - else - sbDirty = sbDirty | horMask; - if ( hideScrollBar && isVisible() ) - repaint( vScrollBar->x(), vScrollBar->y(), - vScrollBar->width(), height() - vScrollBar->y() ); - } - if ( update ) - updateFrameSize(); -} - - - - -int TQtTableView::findRawRow( int yPos, int *cellMaxY, int *cellMinY, - bool goOutsideView ) const -{ - int r = -1; - if ( nRows == 0 ) - return r; - if ( goOutsideView || yPos >= minViewY() && yPos <= maxViewY() ) { - if ( yPos < minViewY() ) { -#if defined(QT_CHECK_RANGE) - tqWarning( "TQtTableView::findRawRow: (%s) internal error: " - "yPos < minViewY() && goOutsideView " - "not supported. (%d,%d)", - name( "unnamed" ), yPos, yOffs ); -#endif - return -1; - } - if ( cellH ) { // uniform cell height - r = (yPos - minViewY() + yCellDelta)/cellH; // cell offs from top - if ( cellMaxY ) - *cellMaxY = (r + 1)*cellH + minViewY() - yCellDelta - 1; - if ( cellMinY ) - *cellMinY = r*cellH + minViewY() - yCellDelta; - r += yCellOffs; // absolute cell index - } else { // variable cell height - TQtTableView *tw = (TQtTableView *)this; - r = yCellOffs; - int h = minViewY() - yCellDelta; //##arnt3 - int oldH = h; - Q_ASSERT( r < nRows ); - while ( r < nRows ) { - oldH = h; - h += tw->cellHeight( r ); // Start of next cell - if ( yPos < h ) - break; - r++; - } - if ( cellMaxY ) - *cellMaxY = h - 1; - if ( cellMinY ) - *cellMinY = oldH; - } - } - return r; - -} - - -int TQtTableView::findRawCol( int xPos, int *cellMaxX, int *cellMinX , - bool goOutsideView ) const -{ - int c = -1; - if ( nCols == 0 ) - return c; - if ( goOutsideView || xPos >= minViewX() && xPos <= maxViewX() ) { - if ( xPos < minViewX() ) { -#if defined(QT_CHECK_RANGE) - tqWarning( "TQtTableView::findRawCol: (%s) internal error: " - "xPos < minViewX() && goOutsideView " - "not supported. (%d,%d)", - name( "unnamed" ), xPos, xOffs ); -#endif - return -1; - } - if ( cellW ) { // uniform cell width - c = (xPos - minViewX() + xCellDelta)/cellW; //cell offs from left - if ( cellMaxX ) - *cellMaxX = (c + 1)*cellW + minViewX() - xCellDelta - 1; - if ( cellMinX ) - *cellMinX = c*cellW + minViewX() - xCellDelta; - c += xCellOffs; // absolute cell index - } else { // variable cell width - TQtTableView *tw = (TQtTableView *)this; - c = xCellOffs; - int w = minViewX() - xCellDelta; //##arnt3 - int oldW = w; - Q_ASSERT( c < nCols ); - while ( c < nCols ) { - oldW = w; - w += tw->cellWidth( c ); // Start of next cell - if ( xPos < w ) - break; - c++; - } - if ( cellMaxX ) - *cellMaxX = w - 1; - if ( cellMinX ) - *cellMinX = oldW; - } - } - return c; -} - - -/* - Returns the index of the row at position \a yPos, where \a yPos is in - \e widget coordinates. Returns -1 if \a yPos is outside the valid - range. - - \sa findCol(), rowYPos() -*/ - -int TQtTableView::findRow( int yPos ) const -{ - int cellMaxY; - int row = findRawRow( yPos, &cellMaxY ); - if ( testTableFlags(Tbl_cutCellsV) && cellMaxY > maxViewY() ) - row = - 1; // cell cut by bottom margin - if ( row >= nRows ) - row = -1; - return row; -} - - -/* - Returns the index of the column at position \a xPos, where \a xPos is - in \e widget coordinates. Returns -1 if \a xPos is outside the valid - range. - - \sa findRow(), colXPos() -*/ - -int TQtTableView::findCol( int xPos ) const -{ - int cellMaxX; - int col = findRawCol( xPos, &cellMaxX ); - if ( testTableFlags(Tbl_cutCellsH) && cellMaxX > maxViewX() ) - col = - 1; // cell cut by right margin - if ( col >= nCols ) - col = -1; - return col; -} - - -/* - Computes the position in the widget of row \a row. - - Returns TRUE and stores the result in \a *yPos (in \e widget - coordinates) if the row is visible. Returns FALSE and does not modify - \a *yPos if \a row is invisible or invalid. - - \sa colXPos(), findRow() -*/ - -bool TQtTableView::rowYPos( int row, int *yPos ) const -{ - int y; - if ( row >= yCellOffs ) { - if ( cellH ) { - int lastVisible = lastRowVisible(); - if ( row > lastVisible || lastVisible == -1 ) - return FALSE; - y = (row - yCellOffs)*cellH + minViewY() - yCellDelta; - } else { - //##arnt3 - y = minViewY() - yCellDelta; // y of leftmost cell in view - int r = yCellOffs; - TQtTableView *tw = (TQtTableView *)this; - int maxY = maxViewY(); - while ( r < row && y <= maxY ) - y += tw->cellHeight( r++ ); - if ( y > maxY ) - return FALSE; - - } - } else { - return FALSE; - } - if ( yPos ) - *yPos = y; - return TRUE; -} - - -/* - Computes the position in the widget of column \a col. - - Returns TRUE and stores the result in \a *xPos (in \e widget - coordinates) if the column is visible. Returns FALSE and does not - modify \a *xPos if \a col is invisible or invalid. - - \sa rowYPos(), findCol() -*/ - -bool TQtTableView::colXPos( int col, int *xPos ) const -{ - int x; - if ( col >= xCellOffs ) { - if ( cellW ) { - int lastVisible = lastColVisible(); - if ( col > lastVisible || lastVisible == -1 ) - return FALSE; - x = (col - xCellOffs)*cellW + minViewX() - xCellDelta; - } else { - //##arnt3 - x = minViewX() - xCellDelta; // x of uppermost cell in view - int c = xCellOffs; - TQtTableView *tw = (TQtTableView *)this; - int maxX = maxViewX(); - while ( c < col && x <= maxX ) - x += tw->cellWidth( c++ ); - if ( x > maxX ) - return FALSE; - } - } else { - return FALSE; - } - if ( xPos ) - *xPos = x; - return TRUE; -} - - -/* - Moves the visible area of the table right by \a xPixels and - down by \a yPixels pixels. Both may be negative. - - \warning You might find that TQScrollView offers a higher-level of - functionality than using TQtTableView and this function. - - This function is \e not the same as TQWidget::scroll(); in particular, - the signs of \a xPixels and \a yPixels have the reverse semantics. - - \sa setXOffset(), setYOffset(), setOffset(), setTopCell(), - setLeftCell() -*/ - -void TQtTableView::scroll( int xPixels, int yPixels ) -{ - TQWidget::scroll( -xPixels, -yPixels, contentsRect() ); -} - - -/* - Returns the leftmost pixel of the table view in \e view - coordinates. This excludes the frame and any header. - - \sa maxViewY(), viewWidth(), contentsRect() -*/ - -int TQtTableView::minViewX() const -{ - return frameWidth(); -} - - -/* - Returns the top pixel of the table view in \e view - coordinates. This excludes the frame and any header. - - \sa maxViewX(), viewHeight(), contentsRect() -*/ - -int TQtTableView::minViewY() const -{ - return frameWidth(); -} - - -/* - Returns the rightmost pixel of the table view in \e view - coordinates. This excludes the frame and any scroll bar, but - includes blank pixels to the right of the visible table data. - - \sa maxViewY(), viewWidth(), contentsRect() -*/ - -int TQtTableView::maxViewX() const -{ - return width() - 1 - frameWidth() - - (tFlags & Tbl_vScrollBar ? VSBEXT - : 0); -} - - -/* - Returns the bottom pixel of the table view in \e view - coordinates. This excludes the frame and any scroll bar, but - includes blank pixels below the visible table data. - - \sa maxViewX(), viewHeight(), contentsRect() -*/ - -int TQtTableView::maxViewY() const -{ - return height() - 1 - frameWidth() - - (tFlags & Tbl_hScrollBar ? HSBEXT - : 0); -} - - -/* - Returns the width of the table view, as such, in \e view - coordinates. This does not include any header, scroll bar or frame, - but it does include background pixels to the right of the table data. - - \sa minViewX() maxViewX(), viewHeight(), contentsRect() viewRect() -*/ - -int TQtTableView::viewWidth() const -{ - return maxViewX() - minViewX() + 1; -} - - -/* - Returns the height of the table view, as such, in \e view - coordinates. This does not include any header, scroll bar or frame, - but it does include background pixels below the table data. - - \sa minViewY() maxViewY() viewWidth() contentsRect() viewRect() -*/ - -int TQtTableView::viewHeight() const -{ - return maxViewY() - minViewY() + 1; -} - - -void TQtTableView::doAutoScrollBars() -{ - int viewW = width() - frameWidth() - minViewX(); - int viewH = height() - frameWidth() - minViewY(); - bool vScrollOn = testTableFlags(Tbl_vScrollBar); - bool hScrollOn = testTableFlags(Tbl_hScrollBar); - int w = 0; - int h = 0; - int i; - - if ( testTableFlags(Tbl_autoHScrollBar) ) { - if ( cellW ) { - w = cellW*nCols; - } else { - i = 0; - while ( i < nCols && w <= viewW ) - w += cellWidth( i++ ); - } - if ( w > viewW ) - hScrollOn = TRUE; - else - hScrollOn = FALSE; - } - - if ( testTableFlags(Tbl_autoVScrollBar) ) { - if ( cellH ) { - h = cellH*nRows; - } else { - i = 0; - while ( i < nRows && h <= viewH ) - h += cellHeight( i++ ); - } - - if ( h > viewH ) - vScrollOn = TRUE; - else - vScrollOn = FALSE; - } - - if ( testTableFlags(Tbl_autoHScrollBar) && vScrollOn && !hScrollOn ) - if ( w > viewW - VSBEXT ) - hScrollOn = TRUE; - - if ( testTableFlags(Tbl_autoVScrollBar) && hScrollOn && !vScrollOn ) - if ( h > viewH - HSBEXT ) - vScrollOn = TRUE; - - setHorScrollBar( hScrollOn, FALSE ); - setVerScrollBar( vScrollOn, FALSE ); - updateFrameSize(); -} - - -/* - \fn void TQtTableView::updateScrollBars() - - Updates the scroll bars' contents and presence to match the table's - state. Generally, you should not need to call this. - - \sa setTableFlags() -*/ - -/* - Updates the scroll bars' contents and presence to match the table's - state \c or \a f. - - \sa setTableFlags() -*/ - -void TQtTableView::updateScrollBars( uint f ) -{ - sbDirty = sbDirty | f; - if ( inSbUpdate ) - return; - inSbUpdate = TRUE; - - if ( testTableFlags(Tbl_autoHScrollBar) && (sbDirty & horRange) || - testTableFlags(Tbl_autoVScrollBar) && (sbDirty & verRange) ) - // if range change and auto - doAutoScrollBars(); // turn scroll bars on/off if needed - - if ( !autoUpdate() ) { - inSbUpdate = FALSE; - return; - } - if ( yOffset() > 0 && testTableFlags( Tbl_autoVScrollBar ) && - !testTableFlags( Tbl_vScrollBar ) ) { - setYOffset( 0 ); - } - if ( xOffset() > 0 && testTableFlags( Tbl_autoHScrollBar ) && - !testTableFlags( Tbl_hScrollBar ) ) { - setXOffset( 0 ); - } - if ( !isVisible() ) { - inSbUpdate = FALSE; - return; - } - - if ( testTableFlags(Tbl_hScrollBar) && (sbDirty & horMask) != 0 ) { - if ( sbDirty & horGeometry ) - hScrollBar->setGeometry( 0,height() - HSBEXT, - viewWidth() + frameWidth()*2, - HSBEXT); - - if ( sbDirty & horSteps ) { - if ( cellW ) - hScrollBar->setSteps( TQMIN(cellW,viewWidth()/2), viewWidth() ); - else - hScrollBar->setSteps( 16, viewWidth() ); - } - - if ( sbDirty & horRange ) - hScrollBar->setRange( 0, maxXOffset() ); - - if ( sbDirty & horValue ) - hScrollBar->setValue( xOffs ); - - // show scrollbar only when it has a sane geometry - if ( !hScrollBar->isVisible() ) - hScrollBar->show(); - } - - if ( testTableFlags(Tbl_vScrollBar) && (sbDirty & verMask) != 0 ) { - if ( sbDirty & verGeometry ) - vScrollBar->setGeometry( width() - VSBEXT, 0, - VSBEXT, - viewHeight() + frameWidth()*2 ); - - if ( sbDirty & verSteps ) { - if ( cellH ) - vScrollBar->setSteps( TQMIN(cellH,viewHeight()/2), viewHeight() ); - else - vScrollBar->setSteps( 16, viewHeight() ); // fttb! ### - } - - if ( sbDirty & verRange ) - vScrollBar->setRange( 0, maxYOffset() ); - - if ( sbDirty & verValue ) - vScrollBar->setValue( yOffs ); - - // show scrollbar only when it has a sane geometry - if ( !vScrollBar->isVisible() ) - vScrollBar->show(); - } - if ( coveringCornerSquare && - ( (sbDirty & verGeometry ) || (sbDirty & horGeometry)) ) - cornerSquare->move( maxViewX() + frameWidth() + 1, - maxViewY() + frameWidth() + 1 ); - - sbDirty = 0; - inSbUpdate = FALSE; -} - - -void TQtTableView::updateFrameSize() -{ - int rw = width() - ( testTableFlags(Tbl_vScrollBar) ? - VSBEXT : 0 ); - int rh = height() - ( testTableFlags(Tbl_hScrollBar) ? - HSBEXT : 0 ); - if ( rw < 0 ) - rw = 0; - if ( rh < 0 ) - rh = 0; - - if ( autoUpdate() ) { - int fh = frameRect().height(); - int fw = frameRect().width(); - setFrameRect( TQRect(0,0,rw,rh) ); - - if ( rw != fw ) - update( TQMIN(fw,rw) - frameWidth() - 2, 0, frameWidth()+4, rh ); - if ( rh != fh ) - update( 0, TQMIN(fh,rh) - frameWidth() - 2, rw, frameWidth()+4 ); - } -} - - -/* - Returns the maximum horizontal offset within the table of the - view's left edge in \e table coordinates. - - This is used mainly to set the horizontal scroll bar's range. - - \sa maxColOffset(), maxYOffset(), totalWidth() -*/ - -int TQtTableView::maxXOffset() -{ - int tw = totalWidth(); - int maxOffs; - if ( testTableFlags(Tbl_scrollLastHCell) ) { - if ( nCols != 1) - maxOffs = tw - ( cellW ? cellW : cellWidth( nCols - 1 ) ); - else - maxOffs = tw - viewWidth(); - } else { - if ( testTableFlags(Tbl_snapToHGrid) ) { - if ( cellW ) { - maxOffs = tw - (viewWidth()/cellW)*cellW; - } else { - int goal = tw - viewWidth(); - int pos = tw; - int nextCol = nCols - 1; - int nextCellWidth = cellWidth( nextCol ); - while( nextCol > 0 && pos > goal + nextCellWidth ) { - pos -= nextCellWidth; - nextCellWidth = cellWidth( --nextCol ); - } - if ( goal + nextCellWidth == pos ) - maxOffs = goal; - else if ( goal < pos ) - maxOffs = pos; - else - maxOffs = 0; - } - } else { - maxOffs = tw - viewWidth(); - } - } - return maxOffs > 0 ? maxOffs : 0; -} - - -/* - Returns the maximum vertical offset within the table of the - view's top edge in \e table coordinates. - - This is used mainly to set the vertical scroll bar's range. - - \sa maxRowOffset(), maxXOffset(), totalHeight() -*/ - -int TQtTableView::maxYOffset() -{ - int th = totalHeight(); - int maxOffs; - if ( testTableFlags(Tbl_scrollLastVCell) ) { - if ( nRows != 1) - maxOffs = th - ( cellH ? cellH : cellHeight( nRows - 1 ) ); - else - maxOffs = th - viewHeight(); - } else { - if ( testTableFlags(Tbl_snapToVGrid) ) { - if ( cellH ) { - maxOffs = th - (viewHeight()/cellH)*cellH; - } else { - int goal = th - viewHeight(); - int pos = th; - int nextRow = nRows - 1; - int nextCellHeight = cellHeight( nextRow ); - while( nextRow > 0 && pos > goal + nextCellHeight ) { - pos -= nextCellHeight; - nextCellHeight = cellHeight( --nextRow ); - } - if ( goal + nextCellHeight == pos ) - maxOffs = goal; - else if ( goal < pos ) - maxOffs = pos; - else - maxOffs = 0; - } - } else { - maxOffs = th - viewHeight(); - } - } - return maxOffs > 0 ? maxOffs : 0; -} - - -/* - Returns the index of the last column, which may be at the left edge - of the view. - - Depending on the \link setTableFlags() Tbl_scrollLastHCell\endlink flag, - this may or may not be the last column. - - \sa maxXOffset(), maxRowOffset() -*/ - -int TQtTableView::maxColOffset() -{ - int mx = maxXOffset(); - if ( cellW ) - return mx/cellW; - else { - int xcd=0, col=0; - while ( col < nCols && mx > (xcd=cellWidth(col)) ) { - mx -= xcd; - col++; - } - return col; - } -} - - -/* - Returns the index of the last row, which may be at the top edge of - the view. - - Depending on the \link setTableFlags() Tbl_scrollLastVCell\endlink flag, - this may or may not be the last row. - - \sa maxYOffset(), maxColOffset() -*/ - -int TQtTableView::maxRowOffset() -{ - int my = maxYOffset(); - if ( cellH ) - return my/cellH; - else { - int ycd=0, row=0; - while ( row < nRows && my > (ycd=cellHeight(row)) ) { - my -= ycd; - row++; - } - return row; - } -} - - -void TQtTableView::showOrHideScrollBars() -{ - if ( !autoUpdate() ) - return; - if ( vScrollBar ) { - if ( testTableFlags(Tbl_vScrollBar) ) { - if ( !vScrollBar->isVisible() ) - sbDirty = sbDirty | verMask; - } else { - if ( vScrollBar->isVisible() ) - vScrollBar->hide(); - } - } - if ( hScrollBar ) { - if ( testTableFlags(Tbl_hScrollBar) ) { - if ( !hScrollBar->isVisible() ) - sbDirty = sbDirty | horMask; - } else { - if ( hScrollBar->isVisible() ) - hScrollBar->hide(); - } - } - if ( cornerSquare ) { - if ( testTableFlags(Tbl_hScrollBar) && - testTableFlags(Tbl_vScrollBar) ) { - if ( !cornerSquare->isVisible() ) - cornerSquare->show(); - } else { - if ( cornerSquare->isVisible() ) - cornerSquare->hide(); - } - } -} - - -/* - Updates the scroll bars and internal state. - - Call this function when the table view's total size is changed; - typically because the result of cellHeight() or cellWidth() have changed. - - This function does not repaint the widget. -*/ - -void TQtTableView::updateTableSize() -{ - bool updateOn = autoUpdate(); - setAutoUpdate( FALSE ); - int xofs = xOffset(); - xOffs++; //so that setOffset will not return immediately - setOffset(xofs,yOffset(),FALSE); //to calculate internal state correctly - setAutoUpdate(updateOn); - - updateScrollBars( horSteps | horRange | - verSteps | verRange ); - showOrHideScrollBars(); -} - - -#endif diff --git a/src/attic/qttableview.h b/src/attic/qttableview.h deleted file mode 100644 index b48f44e1b..000000000 --- a/src/attic/qttableview.h +++ /dev/null @@ -1,250 +0,0 @@ -/********************************************************************** -** -** Definition of TQtTableView class -** -** Created : 941115 -** -** Copyright (C) 1992-2008 Trolltech ASA. All rights reserved. -** -** This file contains a class moved out of the TQt GUI Toolkit API. It -** may be used, distributed and modified without limitation. -** -**********************************************************************/ - -#ifndef TQTTABLEVIEW_H -#define TQTTABLEVIEW_H - -#ifndef QT_H -#include "ntqframe.h" -#endif // QT_H - -#ifndef TQT_NO_QTTABLEVIEW - -class TQScrollBar; -class TQCornerSquare; - - -class TQtTableView : public TQFrame -{ - TQ_OBJECT -public: - virtual void setBackgroundColor( const TQColor & ); - virtual void setPalette( const TQPalette & ); - void show(); - - void repaint( bool erase=TRUE ); - void repaint( int x, int y, int w, int h, bool erase=TRUE ); - void repaint( const TQRect &, bool erase=TRUE ); - -protected: - TQtTableView( TQWidget *parent=0, const char *name=0, WFlags f=0 ); - ~TQtTableView(); - - int numRows() const; - virtual void setNumRows( int ); - int numCols() const; - virtual void setNumCols( int ); - - int topCell() const; - virtual void setTopCell( int row ); - int leftCell() const; - virtual void setLeftCell( int col ); - virtual void setTopLeftCell( int row, int col ); - - int xOffset() const; - virtual void setXOffset( int ); - int yOffset() const; - virtual void setYOffset( int ); - virtual void setOffset( int x, int y, bool updateScrBars = TRUE ); - - virtual int cellWidth( int col ); - virtual int cellHeight( int row ); - int cellWidth() const; - int cellHeight() const; - virtual void setCellWidth( int ); - virtual void setCellHeight( int ); - - virtual int totalWidth(); - virtual int totalHeight(); - - uint tableFlags() const; - bool testTableFlags( uint f ) const; - virtual void setTableFlags( uint f ); - void clearTableFlags( uint f = ~0 ); - - bool autoUpdate() const; - virtual void setAutoUpdate( bool ); - - void updateCell( int row, int column, bool erase=TRUE ); - - TQRect cellUpdateRect() const; - TQRect viewRect() const; - - int lastRowVisible() const; - int lastColVisible() const; - - bool rowIsVisible( int row ) const; - bool colIsVisible( int col ) const; - - TQScrollBar *verticalScrollBar() const; - TQScrollBar *horizontalScrollBar() const; - -private slots: - void horSbValue( int ); - void horSbSliding( int ); - void horSbSlidingDone(); - void verSbValue( int ); - void verSbSliding( int ); - void verSbSlidingDone(); - -protected: - virtual void paintCell( TQPainter *, int row, int col ) = 0; - virtual void setupPainter( TQPainter * ); - - void paintEvent( TQPaintEvent * ); - void resizeEvent( TQResizeEvent * ); - - int findRow( int yPos ) const; - int findCol( int xPos ) const; - - bool rowYPos( int row, int *yPos ) const; - bool colXPos( int col, int *xPos ) const; - - int maxXOffset(); - int maxYOffset(); - int maxColOffset(); - int maxRowOffset(); - - int minViewX() const; - int minViewY() const; - int maxViewX() const; - int maxViewY() const; - int viewWidth() const; - int viewHeight() const; - - void scroll( int xPixels, int yPixels ); - void updateScrollBars(); - void updateTableSize(); - -private: - void coverCornerSquare( bool ); - void snapToGrid( bool horizontal, bool vertical ); - virtual void setHorScrollBar( bool on, bool update = TRUE ); - virtual void setVerScrollBar( bool on, bool update = TRUE ); - void updateView(); - int findRawRow( int yPos, int *cellMaxY, int *cellMinY = 0, - bool goOutsideView = FALSE ) const; - int findRawCol( int xPos, int *cellMaxX, int *cellMinX = 0, - bool goOutsideView = FALSE ) const; - int maxColsVisible() const; - - void updateScrollBars( uint ); - void updateFrameSize(); - - void doAutoScrollBars(); - void showOrHideScrollBars(); - - int nRows; - int nCols; - int xOffs, yOffs; - int xCellOffs, yCellOffs; - short xCellDelta, yCellDelta; - short cellH, cellW; - - uint eraseInPaint : 1; - uint verSliding : 1; - uint verSnappingOff : 1; - uint horSliding : 1; - uint horSnappingOff : 1; - uint coveringCornerSquare : 1; - uint sbDirty : 8; - uint inSbUpdate : 1; - - uint tFlags; - TQRect cellUpdateR; - - TQScrollBar *vScrollBar; - TQScrollBar *hScrollBar; - TQCornerSquare *cornerSquare; - -private: // Disabled copy constructor and operator= -#if defined(TQ_DISABLE_COPY) - TQtTableView( const TQtTableView & ); - TQtTableView &operator=( const TQtTableView & ); -#endif -}; - - -const uint Tbl_vScrollBar = 0x00000001; -const uint Tbl_hScrollBar = 0x00000002; -const uint Tbl_autoVScrollBar = 0x00000004; -const uint Tbl_autoHScrollBar = 0x00000008; -const uint Tbl_autoScrollBars = 0x0000000C; - -const uint Tbl_clipCellPainting = 0x00000100; -const uint Tbl_cutCellsV = 0x00000200; -const uint Tbl_cutCellsH = 0x00000400; -const uint Tbl_cutCells = 0x00000600; - -const uint Tbl_scrollLastHCell = 0x00000800; -const uint Tbl_scrollLastVCell = 0x00001000; -const uint Tbl_scrollLastCell = 0x00001800; - -const uint Tbl_smoothHScrolling = 0x00002000; -const uint Tbl_smoothVScrolling = 0x00004000; -const uint Tbl_smoothScrolling = 0x00006000; - -const uint Tbl_snapToHGrid = 0x00008000; -const uint Tbl_snapToVGrid = 0x00010000; -const uint Tbl_snapToGrid = 0x00018000; - - -inline int TQtTableView::numRows() const -{ return nRows; } - -inline int TQtTableView::numCols() const -{ return nCols; } - -inline int TQtTableView::topCell() const -{ return yCellOffs; } - -inline int TQtTableView::leftCell() const -{ return xCellOffs; } - -inline int TQtTableView::xOffset() const -{ return xOffs; } - -inline int TQtTableView::yOffset() const -{ return yOffs; } - -inline int TQtTableView::cellHeight() const -{ return cellH; } - -inline int TQtTableView::cellWidth() const -{ return cellW; } - -inline uint TQtTableView::tableFlags() const -{ return tFlags; } - -inline bool TQtTableView::testTableFlags( uint f ) const -{ return (tFlags & f) != 0; } - -inline TQRect TQtTableView::cellUpdateRect() const -{ return cellUpdateR; } - -inline bool TQtTableView::autoUpdate() const -{ return isUpdatesEnabled(); } - -inline void TQtTableView::repaint( bool erase ) -{ repaint( 0, 0, width(), height(), erase ); } - -inline void TQtTableView::repaint( const TQRect &r, bool erase ) -{ repaint( r.x(), r.y(), r.width(), r.height(), erase ); } - -inline void TQtTableView::updateScrollBars() -{ updateScrollBars( 0 ); } - - -#endif // TQT_NO_QTTABLEVIEW - -#endif // TQTTABLEVIEW_H |