DriveHQ Start Menu
Cloud Drive Mapping
Folder Sync
Cloud Backup
True Drop Box
FTP/SFTP Hosting
Group Account
DriveHQ Start Menu
Online File Server
My Storage
|
Manage Shares
|
Publishes
|
Drop Boxes
|
Group Account
WebDAV Drive Mapping
Cloud Drive Home
|
WebDAV Guide
|
Drive Mapping Tool
|
Drive Mapping URL
Complete Data Backup
Backup Guide
|
Online Backup Tool
|
Cloud-to-Cloud Backup
FTP, Email & Web Service
FTP Home
|
FTP Hosting FAQ
|
Email Hosting
|
EmailManager
|
Web Hosting
Help & Resources
About
|
Enterprise Service
|
Partnership
|
Comparisons
|
Support
Quick Links
Security and Privacy
Download Software
Service Manual
Use Cases
Group Account
Online Help
Blog
Contact
Cloud Surveillance
Sign Up
Login
Features
Business Features
Online File Server
FTP Hosting
Cloud Drive Mapping
Cloud File Backup
Email Backup & Hosting
Cloud File Sharing
Folder Synchronization
Group Management
True Drop Box
Full-text Search
AD Integration/SSO
Mobile Access
IP Camera & DVR Solution
More...
Personal Features
Personal Cloud Drive
Backup All Devices
Mobile APPs
Personal Web Hosting
Sub-Account (for Kids)
Home/PC/Kids Monitoring
More...
Software
DriveHQ Drive Mapping Tool
DriveHQ FileManager
DriveHQ Online Backup
DriveHQ Mobile Apps
Pricing
Business Plans & Pricing
Personal Plans & Pricing
Price Comparison with Others
Feature Comparison with Others
Install Mobile App
Sign up
Creating account...
Invalid character in username! Only 0-9, a-z, A-Z, _, -, . allowed.
Username is required!
Invalid email address!
E-mail is required!
Password is required!
Password is invalid!
Password and confirmation do not match.
Confirm password is required!
I accept
Membership Agreement
Please read the Membership Agreement and check "I accept"!
Free Quick Sign-up
Sign-up Page
Log in
Signing in...
Username or e-mail address is required!
Password is required!
Keep me logged in
Quick Login
Forgot Password
Up
Upload
Download
Share
Publish
New Folder
New File
Copy
Cut
Delete
Paste
Rate
Upgrade
Rotate
Effect
Edit
Slide
History
/*********************************************************************** filename: CEGUIMultiLineEditbox.h created: 30/6/2004 author: Paul D Turner purpose: Interface to the Multi-lien edit box base class. *************************************************************************/ /*************************************************************************** * Copyright (C) 2004 - 2006 Paul D Turner & The CEGUI Development Team * * Permission is hereby granted, free of charge, to any person obtaining * a copy of this software and associated documentation files (the * "Software"), to deal in the Software without restriction, including * without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to * permit persons to whom the Software is furnished to do so, subject to * the following conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR * OTHER DEALINGS IN THE SOFTWARE. ***************************************************************************/ #ifndef _CEGUIMultiLineEditbox_h_ #define _CEGUIMultiLineEditbox_h_ #include "CEGUIBase.h" #include "CEGUIWindow.h" #include "CEGUIFont.h" #include "elements/CEGUIMultiLineEditboxProperties.h" #include
#if defined(_MSC_VER) # pragma warning(push) # pragma warning(disable : 4251) #endif // Start of CEGUI namespace section namespace CEGUI { /*! \brief Base class for multi-line edit box window renderer objects. */ class CEGUIEXPORT MultiLineEditboxWindowRenderer : public WindowRenderer { public: /*! \brief Constructor */ MultiLineEditboxWindowRenderer(const String& name); /*! \brief Return a Rect object describing, in un-clipped pixels, the window relative area that the text should be rendered in to. \return Rect object describing the area of the Window to be used for rendering text. */ virtual Rect getTextRenderArea(void) const = 0; }; /*! \brief Base class for the multi-line edit box widget. */ class CEGUIEXPORT MultiLineEditbox : public Window { public: static const String EventNamespace; //!< Namespace for global events static const String WidgetTypeName; //!< Window factory name /************************************************************************* Constants *************************************************************************/ // event names static const String EventReadOnlyModeChanged; //!< The read-only mode for the edit box has been changed. static const String EventWordWrapModeChanged; //!< The word wrap mode of the text box has been changed. static const String EventMaximumTextLengthChanged; //!< The maximum allowable string length has been changed. static const String EventCaratMoved; //!< The text carat (insert point) has changed. static const String EventTextSelectionChanged; //!< The current text selection has changed. static const String EventEditboxFull; //!< The number of characters in the edit box has reached the current maximum. static const String EventVertScrollbarModeChanged; //!< Event triggered when the vertical scroll bar 'force' setting changes. static const String EventHorzScrollbarModeChanged; //!< Event triggered when the horizontal scroll bar 'force' setting changes. /************************************************************************* Child Widget name suffix constants *************************************************************************/ static const String VertScrollbarNameSuffix; //!< Widget name suffix for the vertical scrollbar component. static const String HorzScrollbarNameSuffix; //!< Widget name suffix for the horizontal scrollbar component. /************************************************************************* Implementation struct *************************************************************************/ /*! \brief struct used to store information about a formatted line within the paragraph. */ struct LineInfo { size_t d_startIdx; //!< Starting index for this line. size_t d_length; //!< Code point length of this line. float d_extent; //!< Rendered extent of this line. }; typedef std::vector
LineList; //!< Type for collection of LineInfos. /************************************************************************* Accessor Functions *************************************************************************/ /*! \brief return true if the edit box has input focus. \return - true if the edit box has keyboard input focus. - false if the edit box does not have keyboard input focus. */ bool hasInputFocus(void) const; /*! \brief return true if the edit box is read-only. \return - true if the edit box is read only and can't be edited by the user. - false if the edit box is not read only and may be edited by the user. */ bool isReadOnly(void) const {return d_readOnly;} /*! \brief return the current position of the carat. \return Index of the insert carat relative to the start of the text. */ size_t getCaratIndex(void) const {return d_caratPos;} /*! \brief return the current selection start point. \return Index of the selection start point relative to the start of the text. If no selection is defined this function returns the position of the carat. */ size_t getSelectionStartIndex(void) const; /*! \brief return the current selection end point. \return Index of the selection end point relative to the start of the text. If no selection is defined this function returns the position of the carat. */ size_t getSelectionEndIndex(void) const; /*! \brief return the length of the current selection (in code points / characters). \return Number of code points (or characters) contained within the currently defined selection. */ size_t getSelectionLength(void) const; /*! \brief return the maximum text length set for this edit box. \return The maximum number of code points (characters) that can be entered into this edit box. */ size_t getMaxTextLength(void) const {return d_maxTextLen;} /*! \brief Return whether the text in the edit box will be word-wrapped. \return - true if the text will be word-wrapped at the edges of the widget frame. - false if text will not be word-wrapped (a scroll bar will be used to access long text lines). */ bool isWordWrapped(void) const; /*! \brief Return a pointer to the vertical scrollbar component widget for this MultiLineEditbox. \return Pointer to a Scrollbar object. \exception UnknownObjectException Thrown if the vertical Scrollbar component does not exist. */ Scrollbar* getVertScrollbar() const; /*! \brief Return a pointer to the horizontal scrollbar component widget for this MultiLineEditbox. \return Pointer to a Scrollbar object. \exception UnknownObjectException Thrown if the horizontal Scrollbar component does not exist. */ Scrollbar* getHorzScrollbar() const; /*! \brief Return a Rect object describing, in un-clipped pixels, the window relative area that the text should be rendered in to. \return Rect object describing the area of the Window to be used for rendering text. */ Rect getTextRenderArea(void) const; // get d_lines const LineList& getFormattedLines(void) const {return d_lines;} /*! \brief Return the line number a given index falls on with the current formatting. Will return last line if index is out of range. */ size_t getLineNumberFromIndex(size_t index) const; /************************************************************************* Manipulators *************************************************************************/ /*! \brief Initialise the Window based object ready for use. \note This must be called for every window created. Normally this is handled automatically by the WindowFactory for each Window type. \return Nothing */ virtual void initialiseComponents(void); /*! \brief Specify whether the edit box is read-only. \param setting - true if the edit box is read only and can't be edited by the user. - false if the edit box is not read only and may be edited by the user. \return Nothing. */ void setReadOnly(bool setting); /*! \brief Set the current position of the carat. \param carat_pos New index for the insert carat relative to the start of the text. If the value specified is greater than the number of characters in the edit box, the carat is positioned at the end of the text. \return Nothing. */ void setCaratIndex(size_t carat_pos); /*! \brief Define the current selection for the edit box \param start_pos Index of the starting point for the selection. If this value is greater than the number of characters in the edit box, the selection start will be set to the end of the text. \param end_pos Index of the ending point for the selection. If this value is greater than the number of characters in the edit box, the selection start will be set to the end of the text. \return Nothing. */ void setSelection(size_t start_pos, size_t end_pos); /*! \brief set the maximum text length for this edit box. \param max_len The maximum number of code points (characters) that can be entered into this Editbox. \return Nothing. */ void setMaxTextLength(size_t max_len); /*! \brief Scroll the view so that the current carat position is visible. */ void ensureCaratIsVisible(void); /*! \brief Set whether the text will be word wrapped or not. \param setting - true if the text should word-wrap at the edges of the text box. - false if the text should not wrap, but a scroll bar should be used. \return Nothing. */ void setWordWrapping(bool setting); // selection brush image property support void setSelectionBrushImage(const Image* image); const Image* getSelectionBrushImage() const; /************************************************************************* Construction and Destruction *************************************************************************/ /*! \brief Constructor for the MultiLineEditbox base class. */ MultiLineEditbox(const String& type, const String& name); /*! \brief Destructor for the MultiLineEditbox base class. */ virtual ~MultiLineEditbox(void); protected: /************************************************************************* Implementation Methods (abstract) *************************************************************************/ /*! \brief Return a Rect object describing, in un-clipped pixels, the window relative area that the text should be rendered in to. \return Rect object describing the area of the Window to be used for rendering text. */ //virtual Rect getTextRenderArea_impl(void) const = 0; /************************************************************************* Implementation Methods *************************************************************************/ /*! \brief Format the text into lines as needed by the current formatting options. */ void formatText(void); /*! \brief Return the length of the next token in String \a text starting at index \a start_idx. \note Any single whitespace character is one token, any group of other characters is a token. \return The code point length of the token. */ size_t getNextTokenLength(const String& text, size_t start_idx) const; /*! \brief display required integrated scroll bars according to current state of the edit box and update their values. */ void configureScrollbars(void); /*! \brief Return the text code point index that is rendered closest to screen position \a pt. \param pt Point object describing a position on the screen in pixels. \return Code point index into the text that is rendered closest to screen position \a pt. */ size_t getTextIndexFromPosition(const Point& pt) const; /*! \brief Clear the current selection setting */ void clearSelection(void); /*! \brief Erase the currently selected text. \param modify_text when true, the actual text will be modified. When false, everything is done except erasing the characters. */ void eraseSelectedText(bool modify_text = true); /*! \brief Processing for backspace key */ void handleBackspace(void); /*! \brief Processing for Delete key */ void handleDelete(void); /*! \brief Processing to move carat one character left */ void handleCharLeft(uint sysKeys); /*! \brief Processing to move carat one word left */ void handleWordLeft(uint sysKeys); /*! \brief Processing to move carat one character right */ void handleCharRight(uint sysKeys); /*! \brief Processing to move carat one word right */ void handleWordRight(uint sysKeys); /*! \brief Processing to move carat to the start of the text. */ void handleDocHome(uint sysKeys); /*! \brief Processing to move carat to the end of the text */ void handleDocEnd(uint sysKeys); /*! \brief Processing to move carat to the start of the current line. */ void handleLineHome(uint sysKeys); /*! \brief Processing to move carat to the end of the current line */ void handleLineEnd(uint sysKeys); /*! \brief Processing to move carat up a line. */ void handleLineUp(uint sysKeys); /*! \brief Processing to move carat down a line. */ void handleLineDown(uint sysKeys); /*! \brief Processing to insert a new line / paragraph. */ void handleNewLine(uint sysKeys); /*! \brief Processing to move caret one page up */ void handlePageUp(uint sysKeys); /*! \brief Processing to move caret one page down */ void handlePageDown(uint sysKeys); /*! \brief Return whether this window was inherited from the given class name at some point in the inheritance hierarchy. \param class_name The class name that is to be checked. \return true if this window was inherited from \a class_name. false if not. */ virtual bool testClassName_impl(const String& class_name) const { if ((class_name=="MultiLineEditBox") || (class_name=="MultiLineEditbox")) { return true; } return Window::testClassName_impl(class_name); } /*! \brief Internal handler that is triggered when the user interacts with the scrollbars. */ bool handle_scrollChange(const EventArgs& args); // validate window renderer virtual bool validateWindowRenderer(const String& name) const { return (name == EventNamespace); } /************************************************************************* New event handlers *************************************************************************/ /*! \brief Handler called when the read-only state of the edit box changes */ void onReadOnlyChanged(WindowEventArgs& e); /*! \brief Handler called when the word wrap mode for the the edit box changes */ void onWordWrapModeChanged(WindowEventArgs& e); /*! \brief Handler called when the maximum text length for the edit box changes */ void onMaximumTextLengthChanged(WindowEventArgs& e); /*! \brief Handler called when the carat moves. */ void onCaratMoved(WindowEventArgs& e); /*! \brief Handler called when the text selection changes */ void onTextSelectionChanged(WindowEventArgs& e); /*! \brief Handler called when the edit box is full */ void onEditboxFullEvent(WindowEventArgs& e); /*! \brief Handler called when the 'always show' setting for the vertical scroll bar changes. */ void onVertScrollbarModeChanged(WindowEventArgs& e); /*! \brief Handler called when 'always show' setting for the horizontal scroll bar changes. */ void onHorzScrollbarModeChanged(WindowEventArgs& e); /************************************************************************* Overridden event handlers *************************************************************************/ virtual void onMouseButtonDown(MouseEventArgs& e); virtual void onMouseButtonUp(MouseEventArgs& e); virtual void onMouseDoubleClicked(MouseEventArgs& e); virtual void onMouseTripleClicked(MouseEventArgs& e); virtual void onMouseMove(MouseEventArgs& e); virtual void onCaptureLost(WindowEventArgs& e); virtual void onCharacter(KeyEventArgs& e); virtual void onKeyDown(KeyEventArgs& e); virtual void onTextChanged(WindowEventArgs& e); virtual void onSized(WindowEventArgs& e); virtual void onMouseWheel(MouseEventArgs& e); /************************************************************************* Implementation data *************************************************************************/ bool d_readOnly; //!< true if the edit box is in read-only mode size_t d_maxTextLen; //!< Maximum number of characters for this Editbox. size_t d_caratPos; //!< Position of the carat / insert-point. size_t d_selectionStart; //!< Start of selection area. size_t d_selectionEnd; //!< End of selection area. bool d_dragging; //!< true when a selection is being dragged. size_t d_dragAnchorIdx; //!< Selection index for drag selection anchor point. static String d_lineBreakChars; //!< Holds what we consider to be line break characters. bool d_wordWrap; //!< true when formatting uses word-wrapping. LineList d_lines; //!< Holds the lines for the current formatting. float d_widestExtent; //!< Holds the extent of the widest line as calculated in the last formatting pass. // component widget settings bool d_forceVertScroll; //!< true if vertical scrollbar should always be displayed bool d_forceHorzScroll; //!< true if horizontal scrollbar should always be displayed // images const Image* d_selectionBrush; //!< Image to use as the selection brush (should be set by derived class). private: /************************************************************************* Static Properties for this class *************************************************************************/ static MultiLineEditboxProperties::ReadOnly d_readOnlyProperty; static MultiLineEditboxProperties::WordWrap d_wordWrapProperty; static MultiLineEditboxProperties::CaratIndex d_caratIndexProperty; static MultiLineEditboxProperties::SelectionStart d_selectionStartProperty; static MultiLineEditboxProperties::SelectionLength d_selectionLengthProperty; static MultiLineEditboxProperties::MaxTextLength d_maxTextLengthProperty; static MultiLineEditboxProperties::SelectionBrushImage d_selectionBrushProperty; /************************************************************************* Private methods *************************************************************************/ void addMultiLineEditboxProperties(void); }; } // End of CEGUI namespace section #if defined(_MSC_VER) # pragma warning(pop) #endif #endif // end of guard _CEGUIMultiLineEditbox_h_
CEGUIMultiLineEditbox.h
Page URL
File URL
Prev
36/65
Next
Download
( 19 KB )
Note: The DriveHQ service banners will NOT be displayed if the file owner is a paid member.
Comments
Total ratings:
0
Average rating:
Not Rated
Would you like to comment?
Join DriveHQ
for a free account, or
Logon
if you are already a member.