diff options
Diffstat (limited to 'src/gwin/gwin_textedit.h')
| -rw-r--r-- | src/gwin/gwin_textedit.h | 68 | 
1 files changed, 68 insertions, 0 deletions
| diff --git a/src/gwin/gwin_textedit.h b/src/gwin/gwin_textedit.h new file mode 100644 index 00000000..f83233b4 --- /dev/null +++ b/src/gwin/gwin_textedit.h @@ -0,0 +1,68 @@ +/* + * This file is subject to the terms of the GFX License. If a copy of + * the license was not distributed with this file, you can obtain one at: + * + *              http://ugfx.org/license.html + */ + +/** + * @file	src/gwin/gwin_textedit.h + * @brief	GWIN textedit widget header file + * + * @defgroup TextEdit TextEdit + * @ingroup Widgets + * + * @details		A GWIN TextEdit widget allows user input. + * + * @pre			GFX_USE_GDISP must be set to TRUE in your gfxconf.h + * @pre			GFX_USE_GWIN must be set to TRUE in your gfxconf.h + * @pre			GDISP_NEED_TEXT must be set to TRUE in your gfxconf.h + * @pre			GWIN_NEED_TEXTEDIT must be set to TRUE in your gfxconf.h + * @pre			The fonts you want to use must be enabled in your gfxconf.h + * + * @{ + */ + +#ifndef _GWIN_TEXTEDIT_H +#define _GWIN_TEXTEDIT_H + +// This file is included within "src/gwin/gwin_widget.h" + +// A TextEdit widget +typedef struct GTexteditObject { +	GWidgetObject	w; + +	char*			textBuffer; +	size_t			maxSize; +	uint16_t		cursorPos; +} GTexteditObject; + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief				Create a TextEdit widget + * @details				A TextEdit widget is a rectangular box which allows the user to input data through a keyboard. + *						The keyboard can either be a physical one or a virtual on-screen keyboard as the keyboard driver + *						is abstracted through the GINPUT module. + * + * @param[in] g			The GDisplay on which the textedit should be displayed + * @param[in] wt		The TextEdit structure to initialise. If this is NULL, the structure is dynamically allocated. + * @param[in] pInit		The initialisation parameters to use. + * @param[in] maxSize	The maximum number of characters the TextEdit widget can hold. + * + * @return				NULL if there is no resultant drawing area, otherwise the widget handle. + * + * @note				If the initial text set is larger than maxSize then the text is truncated at maxSize characters. + * @api + */ +GHandle gwinGTexteditCreate(GDisplay* g, GTexteditObject* wt, GWidgetInit* pInit, size_t maxSize); +#define gwinTexteditCreate(wt, pInit, maxSize)			gwinGTexteditCreate(GDISP, wt, pInit, maxSize) + +#ifdef __cplusplus +} +#endif + +#endif // _GWIN_TEXTEDIT_H +/** @} */ | 
