Source code of Windows XP (NT5)
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.

185 lines
4.5 KiB

  1. //
  2. // TXTED.HPP
  3. // Text Object Editor
  4. //
  5. // Copyright Microsoft 1998-
  6. //
  7. #ifndef __TXTED_HPP_
  8. #define __TXTED_HPP_
  9. #define MIN_IME_WINDOW 30
  10. #define MIN_FITBOX_CHARS 6
  11. class WbTextEditor;
  12. /////////////////////////////////////////////////////////////////////////////
  13. // WbTextBox window
  14. class WbTextBox
  15. {
  16. public:
  17. WbTextBox(WbTextEditor * pEditor);
  18. ~WbTextBox();
  19. BOOL Create(HWND hwndParent);
  20. BOOL FitBox( void );
  21. void AutoCaretScroll( void );
  22. int GetMaxCharHeight( void );
  23. int GetMaxCharWidth( void );
  24. void AbortEditGently( void );
  25. HWND m_hwnd;
  26. POINT m_ptNTBooger;
  27. friend LRESULT CALLBACK TextWndProc(HWND, UINT, WPARAM, LPARAM);
  28. WNDPROC m_pfnEditPrev;
  29. protected:
  30. RECT m_MaxRect;
  31. WbTextEditor *m_pEditor;
  32. RECT m_rectErase;
  33. BOOL m_bInIME;
  34. BOOL m_bDontEscapeThisTime;
  35. void SetupBackgroundRepaint( POINT ptTopPaint, BOOL bNumLinesChanged=TRUE );
  36. void SelectAtLeastOne( void );
  37. void OnClearCut(void);
  38. void OnUndoPaste(void);
  39. void OnChar(UINT nChar, UINT nRepCnt, UINT nFlags);
  40. void OnKeyUp(UINT nChar, UINT nRepCnt, UINT nFlags);
  41. void OnTimer(UINT nIDEvent);
  42. void OnLButtonUp(UINT nFlags, int x, int y);
  43. void OnMouseMove(UINT nFlags, int x, int y);
  44. void OnMove(int x, int y);
  45. void OnSysKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags);
  46. };
  47. /////////////////////////////////////////////////////////////////////////////
  48. //
  49. //
  50. // Class: WbTextEditor
  51. //
  52. // Purpose: Allow editing of the text in a DCWbGraphicText object
  53. //
  54. //
  55. class WbTextEditor : public TextObj
  56. {
  57. friend class WbTextBox;
  58. friend class WbDrawingArea;
  59. public:
  60. //
  61. // Constructor
  62. //
  63. WbTextEditor(void);
  64. ~WbTextEditor(void);
  65. // writes text to underlying text object before relaying to text object
  66. DWORD CalculateExternalLength(void);
  67. // calcs bounds rect and sets editbox to new size
  68. void CalculateBoundsRect(void);
  69. void SetTimer( UINT nElapse );
  70. void KillTimer( void );
  71. // set editbox visibility
  72. void ShowBox( int nShow );
  73. BOOL Create( void );
  74. // Moves underlying text object and then moves editbox rect
  75. void MoveBy(int cx, int cy);
  76. void RedrawEditbox(void);
  77. // resets editbox for parent resizing
  78. void ParentResize( void );
  79. // clipboard
  80. void Copy( void )
  81. { ::SendMessage(m_pEditBox->m_hwnd, WM_COPY, 0, 0); }
  82. void Cut( void )
  83. { ::SendMessage(m_pEditBox->m_hwnd, WM_CUT, 0, 0); }
  84. void Paste( void )
  85. { ::SendMessage(m_pEditBox->m_hwnd, WM_PASTE, 0, 0); }
  86. virtual void SetFont( LOGFONT *pLogFont, BOOL bDummy=TRUE );
  87. virtual void SetFont(HFONT hFont) { TextObj::SetFont(hFont); }
  88. //
  89. // Attach a text object to the editor. This function copies the
  90. // contents of the specified text object into the text editor. The
  91. // editor will not alter the contents of the object passed and does not
  92. // keep a copy of the pointer parameter.
  93. //
  94. BOOL SetTextObject(TextObj * ptext);
  95. //
  96. // Return the width and height for the cursor in pixels as a size
  97. //
  98. void GetCursorSize(LPSIZE lpsize);
  99. //
  100. // Set the current edit cursor position from a point specified in
  101. // logical co-ordinates. This function does nothing if the point
  102. // specified is outside the bounding rectangle of the object being
  103. // edited. If the point specified is within the bounding rectangle the
  104. // current edit cursor position is updated to a point as close as
  105. // possible to that passed as parameter.
  106. //
  107. void SetCursorPosFromPoint(POINT pointXY);
  108. void Clear(void); // Delete all text
  109. BOOL New(void); // Delete text and reset handles
  110. //
  111. // Return TRUE if there is not text in the object
  112. //
  113. BOOL IsEmpty(void);
  114. void AbortEditGently( void )
  115. {m_pEditBox->AbortEditGently();}
  116. WbTextBox *m_pEditBox;
  117. protected:
  118. //
  119. // Pixel position from a character position
  120. //
  121. void GetXYPosition(POINT pointChar, LPPOINT lpptGet);
  122. //
  123. // Current cursor position. Note that cursorCharPos.x gives the BYTE
  124. // position of the cursor rather than the character position. On SBCS
  125. // systems the character and byte positions will always be the same,
  126. // but on DBCS systems the number of bytes in a string can be greater
  127. // than the number of characters.
  128. //
  129. // cursorCharPos.x should NEVER be set to a byte count which is in the
  130. // middle of a double byte character.
  131. //
  132. POINT m_cursorCharPos;
  133. POINT m_cursorXYPos;
  134. int m_nLastShow;
  135. void PutText(void);
  136. void GetText(void);
  137. };
  138. #endif // __TXTED_HPP_