You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
175 lines
4.5 KiB
175 lines
4.5 KiB
/*
|
|
**************************************************************************
|
|
description
|
|
--------------------
|
|
copyright : (C) 2002 by Andreas Zehender
|
|
email : zehender@kde.org
|
|
**************************************************************************
|
|
|
|
**************************************************************************
|
|
* *
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
* it under the terms of the GNU General Public License as published by *
|
|
* the Free Software Foundation; either version 2 of the License, or *
|
|
* (at your option) any later version. *
|
|
* *
|
|
**************************************************************************/
|
|
|
|
#ifndef PMVECTORLISTEDIT_H
|
|
#define PMVECTORLISTEDIT_H
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
#include <config.h>
|
|
#endif
|
|
|
|
#include <tqtable.h>
|
|
#include <tqvaluelist.h>
|
|
#include <tqmemarray.h>
|
|
|
|
#include "pmvector.h"
|
|
|
|
/*
|
|
const int c_pmTableRTTI = 14352;
|
|
|
|
class PMTableItem : public TQTableItem
|
|
{
|
|
public:
|
|
PMTableItem( TQTable* table );
|
|
|
|
virtual void paint( TQPainter* p, const TQColorGroup& cg,
|
|
const TQRect& cr, bool selected );
|
|
|
|
int rtti( ) const { return c_pmTableRTTI; }
|
|
|
|
void setReadOnly( bool r ) { m_readOnly = r; }
|
|
bool isReadOnly( ) const { return m_readOnly; }
|
|
|
|
private:
|
|
bool m_readOnly;
|
|
};
|
|
*/
|
|
|
|
|
|
/**
|
|
* Widget that displays a list of vectors, based on @ref TQTable.
|
|
*/
|
|
class PMVectorListEdit : public TQTable
|
|
{
|
|
TQ_OBJECT
|
|
|
|
public:
|
|
/**
|
|
* Constructor for 3d vectors (x, y, z)
|
|
*/
|
|
PMVectorListEdit( TQWidget* parent, const char* name = 0 );
|
|
/**
|
|
* Constructor for 3d vectors
|
|
*/
|
|
PMVectorListEdit( const TQString& c1, const TQString& c2, const TQString& c3,
|
|
TQWidget* parent, const char* name = 0 );
|
|
/**
|
|
* Constructor for 2d vectors
|
|
*/
|
|
PMVectorListEdit( const TQString& c1, const TQString& c2,
|
|
TQWidget* parent, const char* name = 0 );
|
|
|
|
/**
|
|
* Constructor for 4d vectors
|
|
*/
|
|
PMVectorListEdit( const TQString& c1, const TQString& c2, const TQString& c3,
|
|
const TQString& c4, TQWidget* parent, const char* name = 0 );
|
|
/**
|
|
* Sets and displays the vectors. The widget will automatically
|
|
* resize if no link is set and resize is true.
|
|
*/
|
|
void setVectors( const TQValueList<PMVector>& v, bool resize = false,
|
|
int precision = 5 );
|
|
/**
|
|
* Returns the vectors
|
|
*/
|
|
TQValueList<PMVector> vectors( ) const;
|
|
/**
|
|
* Sets the i-th vector
|
|
*/
|
|
void setVector( int i, const PMVector& v, int precision = 5 );
|
|
/**
|
|
* Returns the i-th vector
|
|
*/
|
|
PMVector vector( int i ) const;
|
|
/**
|
|
* Sets the number of vectors
|
|
*/
|
|
void setSize( int s );
|
|
/**
|
|
* Returns the number of vectors
|
|
*/
|
|
int size( ) const { return m_size; }
|
|
|
|
/**
|
|
* Adds a linked point. The point p2 will be disabled and synchronized
|
|
* with p1.
|
|
*
|
|
* Call this method before displaying vectors and remove the point
|
|
* p2 from the vector list before you call @ref setVectors( ).
|
|
* The list returned by @ref vectors( ) will not return this point.
|
|
*
|
|
* Set p2 to -1 to remove a link.
|
|
*/
|
|
void setLink( int p1, int p2 );
|
|
/**
|
|
* Removes all links. The widget is not updated. You have to resize
|
|
* the widget and redisplay the points.
|
|
*/
|
|
void clearLinks( );
|
|
|
|
/**
|
|
* Returns the selection status of vector i
|
|
*/
|
|
bool isSelected( int i ) const;
|
|
/**
|
|
* Selects vector i
|
|
*/
|
|
void select( int i );
|
|
/**
|
|
* Selects vector i to j
|
|
*/
|
|
void select( int i, int j );
|
|
/**
|
|
* Blocks/unblocks selection updates. If block is false, the
|
|
* selection is repainted.
|
|
*/
|
|
void blockSelectionUpdates( bool block );
|
|
|
|
/**
|
|
* Returns true if the edited data is valid.
|
|
*/
|
|
bool isDataValid( );
|
|
|
|
/** */
|
|
virtual TQSize sizeHint( ) const;
|
|
/** */
|
|
bool eventFilter( TQObject* o, TQEvent* e );
|
|
|
|
protected slots:
|
|
void slotTextChanged( int, int );
|
|
|
|
signals:
|
|
/**
|
|
* Emitted when the used edits a field
|
|
*/
|
|
void dataChanged( );
|
|
/**
|
|
* Emitted after a right mouse button click
|
|
*/
|
|
void showContextMenu( );
|
|
private:
|
|
void init( int dimensions );
|
|
|
|
int m_dimension, m_size;
|
|
TQMemArray<int> m_links;
|
|
TQMemArray<bool> m_disabled;
|
|
};
|
|
|
|
|
|
#endif
|