home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / qt3_emx.zip / include / qcursor.h < prev    next >
C/C++ Source or Header  |  2001-10-11  |  4KB  |  150 lines

  1. /****************************************************************************
  2. ** $Id:  qt/qcursor.h   3.0.0   edited Sep 26 09:25 $
  3. **
  4. ** Definition of QCursor class
  5. **
  6. ** Created : 940219
  7. **
  8. ** Copyright (C) 1992-2000 Trolltech AS.  All rights reserved.
  9. **
  10. ** This file is part of the kernel module of the Qt GUI Toolkit.
  11. **
  12. ** This file may be distributed under the terms of the Q Public License
  13. ** as defined by Trolltech AS of Norway and appearing in the file
  14. ** LICENSE.QPL included in the packaging of this file.
  15. **
  16. ** This file may be distributed and/or modified under the terms of the
  17. ** GNU General Public License version 2 as published by the Free Software
  18. ** Foundation and appearing in the file LICENSE.GPL included in the
  19. ** packaging of this file.
  20. **
  21. ** Licensees holding valid Qt Enterprise Edition or Qt Professional Edition
  22. ** licenses may use this file in accordance with the Qt Commercial License
  23. ** Agreement provided with the Software.
  24. **
  25. ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
  26. ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  27. **
  28. ** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
  29. **   information about Qt Commercial License Agreements.
  30. ** See http://www.trolltech.com/qpl/ for QPL licensing information.
  31. ** See http://www.trolltech.com/gpl/ for GPL licensing information.
  32. **
  33. ** Contact info@trolltech.com if any conditions of this licensing are
  34. ** not clear to you.
  35. **
  36. **********************************************************************/
  37.  
  38. #ifndef QCURSOR_H
  39. #define QCURSOR_H
  40.  
  41. #ifndef QT_H
  42. #include "qpoint.h"
  43. #include "qshared.h"
  44. #endif // QT_H
  45.  
  46. /*
  47.   ### The fake cursor has to go first with old qdoc.
  48. */
  49. #ifdef QT_NO_CURSOR
  50.  
  51. class Q_EXPORT QCursor : public Qt
  52. {
  53. public:
  54.     static QPoint pos();
  55.     static void      setPos( int x, int y );
  56.     static void      setPos( const QPoint & );
  57. private:
  58.     QCursor();
  59. };
  60.  
  61. #endif // QT_NO_CURSOR
  62.  
  63. #ifndef QT_NO_CURSOR
  64.  
  65. struct QCursorData;
  66.  
  67.  
  68. class Q_EXPORT QCursor : public Qt
  69. {
  70. public:
  71.     QCursor();                // create default arrow cursor
  72.     QCursor( int shape );
  73.     QCursor( const QBitmap &bitmap, const QBitmap &mask,
  74.          int hotX=-1, int hotY=-1 );
  75.     QCursor( const QPixmap &pixmap,
  76.          int hotX=-1, int hotY=-1 );
  77.     QCursor( const QCursor & );
  78.    ~QCursor();
  79.     QCursor &operator=( const QCursor & );
  80.  
  81.     int          shape()   const;
  82.     void      setShape( int );
  83.  
  84.     const QBitmap *bitmap() const;
  85.     const QBitmap *mask()   const;
  86.     QPoint      hotSpot() const;
  87.  
  88. #if defined(Q_WS_WIN)
  89.     HCURSOR      handle()  const;
  90.     QCursor( HCURSOR );
  91. #elif defined(Q_WS_X11)
  92.     HANDLE      handle()  const;
  93. #elif defined(Q_WS_MAC)
  94.     HANDLE handle() const;
  95. #elif defined(Q_WS_QWS)
  96.     HANDLE      handle()  const;
  97. #endif
  98.  
  99.     static QPoint pos();
  100.     static void      setPos( int x, int y );
  101.     static void      setPos( const QPoint & );
  102.  
  103.     static void      initialize();
  104.     static void      cleanup();
  105.  
  106. #if defined(Q_WS_X11)
  107.     static int       x11Screen();
  108. #endif
  109. private:
  110.     void      setBitmap( const QBitmap &bitmap, const QBitmap &mask,
  111.                  int hotX, int hotY );
  112.     void      update() const;
  113.     QCursorData     *data;
  114.     QCursor     *find_cur(int);
  115. #if defined(Q_WS_MAC)
  116.     friend void qt_mac_set_cursor(const QCursor *c, const Point *p);
  117. #endif
  118. };
  119.  
  120.  
  121. #if !defined(QT_CLEAN_NAMESPACE)
  122. // CursorShape is defined in X11/X.h
  123. #ifdef CursorShape
  124. #define X_CursorShape CursorShape
  125. #undef CursorShape
  126. #endif
  127. typedef Qt::CursorShape QCursorShape;
  128. #ifdef X_CursorShape
  129. #define CursorShape X_CursorShape
  130. #endif
  131. #endif
  132.  
  133.  
  134. /*****************************************************************************
  135.   QCursor stream functions
  136.  *****************************************************************************/
  137. #ifndef QT_NO_DATASTREAM
  138. Q_EXPORT QDataStream &operator<<( QDataStream &, const QCursor & );
  139. Q_EXPORT QDataStream &operator>>( QDataStream &, QCursor & );
  140. #endif
  141. #endif // QT_NO_CURSOR
  142.  
  143.  
  144. inline void QCursor::setPos( const QPoint &p )
  145. {
  146.     setPos( p.x(), p.y() );
  147. }
  148.  
  149. #endif // QCURSOR_H
  150.