forked from enlightenment/efl
parent
acf4ca6139
commit
f35fd9762e
|
@ -33,6 +33,30 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @defgroup Ecore_IMF_Context_Group Ecore Input Method Context Functions
|
||||||
|
* @ingroup Ecore_IMF_Lib_Group
|
||||||
|
*
|
||||||
|
* Functions that operate on Ecore Input Method Context objects.
|
||||||
|
|
||||||
|
* Ecore Input Method Context Function defines the interface for EFL input methods.
|
||||||
|
* An input method is used by EFL text input widgets like elm_entry
|
||||||
|
* (based on edje_entry) to map from key events to Unicode character strings.
|
||||||
|
*
|
||||||
|
* The default input method can be set through setting the ECORE_IMF_MODULE environment variable.
|
||||||
|
*
|
||||||
|
* An input method may consume multiple key events in sequence and finally output the composed result.
|
||||||
|
* This is called preediting, and an input method may provide feedback about
|
||||||
|
* this process by displaying the intermediate composition states as preedit text.
|
||||||
|
*
|
||||||
|
* Immodule is plugin to connect your application and input method framework such as SCIM, ibus, and so on.@n
|
||||||
|
* ecore_imf_init() should be called to initialize and load immodule.@n
|
||||||
|
* ecore_imf_shutdown() is used for shutdowning and unloading immodule.
|
||||||
|
*
|
||||||
|
* An example of usage of these functions can be found at:
|
||||||
|
* @li @ref ecore_imf_example_c
|
||||||
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @addtogroup Ecore_IMF_Context_Group
|
* @addtogroup Ecore_IMF_Context_Group
|
||||||
*
|
*
|
||||||
|
@ -53,7 +77,8 @@ typedef enum
|
||||||
{
|
{
|
||||||
ECORE_IMF_INPUT_PANEL_STATE_SHOW, /**< Notification after the display of the input panel @since 1.7 */
|
ECORE_IMF_INPUT_PANEL_STATE_SHOW, /**< Notification after the display of the input panel @since 1.7 */
|
||||||
ECORE_IMF_INPUT_PANEL_STATE_HIDE, /**< Notification prior to the dismissal of the input panel @since 1.7 */
|
ECORE_IMF_INPUT_PANEL_STATE_HIDE, /**< Notification prior to the dismissal of the input panel @since 1.7 */
|
||||||
ECORE_IMF_INPUT_PANEL_STATE_WILL_SHOW /**< Notification prior to the display of the input panel @since 1.7 */
|
ECORE_IMF_INPUT_PANEL_STATE_WILL_SHOW, /**< Notification prior to the display of the input panel @since 1.7 */
|
||||||
|
ECORE_IMF_INPUT_PANEL_STATE_WILL_HIDE /**< Notification prior to the dismissal of the input panel @since 1.8 */
|
||||||
} Ecore_IMF_Input_Panel_State;
|
} Ecore_IMF_Input_Panel_State;
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
|
@ -237,8 +262,10 @@ typedef enum
|
||||||
ECORE_IMF_INPUT_PANEL_LAYOUT_NUMBERONLY, /**< Number Only layout */
|
ECORE_IMF_INPUT_PANEL_LAYOUT_NUMBERONLY, /**< Number Only layout */
|
||||||
ECORE_IMF_INPUT_PANEL_LAYOUT_INVALID, /**< Never use this */
|
ECORE_IMF_INPUT_PANEL_LAYOUT_INVALID, /**< Never use this */
|
||||||
ECORE_IMF_INPUT_PANEL_LAYOUT_HEX, /**< Hexadecimal layout @since 1.2 */
|
ECORE_IMF_INPUT_PANEL_LAYOUT_HEX, /**< Hexadecimal layout @since 1.2 */
|
||||||
ECORE_IMF_INPUT_PANEL_LAYOUT_TERMINAL, /**< Command-line terminal layout including esc, alt, ctrl key, so on (no auto-correct, no auto-capitalization) @since 1.2 */
|
ECORE_IMF_INPUT_PANEL_LAYOUT_TERMINAL, /**< Command-line terminal layout including ESC, Alt, Ctrl key, so on (no auto-correct, no auto-capitalization) @since 1.2 */
|
||||||
ECORE_IMF_INPUT_PANEL_LAYOUT_PASSWORD /**< Like normal, but no auto-correct, no auto-capitalization etc. @since 1.2 */
|
ECORE_IMF_INPUT_PANEL_LAYOUT_PASSWORD, /**< Like normal, but no auto-correct, no auto-capitalization etc. @since 1.2 */
|
||||||
|
ECORE_IMF_INPUT_PANEL_LAYOUT_NAME, /**< Name layout */
|
||||||
|
ECORE_IMF_INPUT_PANEL_LAYOUT_ADDRESS, /**< Address layout */
|
||||||
} Ecore_IMF_Input_Panel_Layout;
|
} Ecore_IMF_Input_Panel_Layout;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -489,76 +516,926 @@ EAPI int ecore_imf_shutdown(void);
|
||||||
|
|
||||||
EAPI void ecore_imf_module_register(const Ecore_IMF_Context_Info *info, Ecore_IMF_Context *(*imf_module_create)(void), Ecore_IMF_Context *(*imf_module_exit)(void));
|
EAPI void ecore_imf_module_register(const Ecore_IMF_Context_Info *info, Ecore_IMF_Context *(*imf_module_create)(void), Ecore_IMF_Context *(*imf_module_exit)(void));
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the list of the available Input Method Context ids.
|
||||||
|
*
|
||||||
|
* Note that the caller is responsible for freeing the Eina_List
|
||||||
|
* when finished with it. There is no need to finish the list strings.
|
||||||
|
*
|
||||||
|
* @return Return an Eina_List of strings;
|
||||||
|
* on failure it returns NULL.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI Eina_List *ecore_imf_context_available_ids_get(void);
|
EAPI Eina_List *ecore_imf_context_available_ids_get(void);
|
||||||
EAPI Eina_List *ecore_imf_context_available_ids_by_canvas_type_get(const char *canvas_type);
|
EAPI Eina_List *ecore_imf_context_available_ids_by_canvas_type_get(const char *canvas_type);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the id of the default Input Method Context.
|
||||||
|
* The id may to used to create a new instance of an Input Method
|
||||||
|
* Context object.
|
||||||
|
*
|
||||||
|
* @return Return a string containing the id of the default Input
|
||||||
|
* Method Context; on failure it returns NULL.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI const char *ecore_imf_context_default_id_get(void);
|
EAPI const char *ecore_imf_context_default_id_get(void);
|
||||||
EAPI const char *ecore_imf_context_default_id_by_canvas_type_get(const char *canvas_type);
|
EAPI const char *ecore_imf_context_default_id_by_canvas_type_get(const char *canvas_type);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve the info for the Input Method Context with @p id.
|
||||||
|
*
|
||||||
|
* @param id The Input Method Context id to query for.
|
||||||
|
* @return Return a #Ecore_IMF_Context_Info for the Input Method Context with @p id;
|
||||||
|
* on failure it returns NULL.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*
|
||||||
|
* Example
|
||||||
|
* @code
|
||||||
|
*
|
||||||
|
* const char *ctx_id;
|
||||||
|
* const Ecore_IMF_Context_Info *ctx_info;
|
||||||
|
* Ecore_IMF_Context *imf_context;
|
||||||
|
* ctx_id = ecore_imf_context_default_id_get();
|
||||||
|
* if (ctx_id)
|
||||||
|
* {
|
||||||
|
* ctx_info = ecore_imf_context_info_by_id_get(ctx_id);
|
||||||
|
* if (!ctx_info->canvas_type ||
|
||||||
|
* strcmp(ctx_info->canvas_type, "evas") == 0)
|
||||||
|
* {
|
||||||
|
* imf_context = ecore_imf_context_add(ctx_id);
|
||||||
|
* }
|
||||||
|
* else
|
||||||
|
* {
|
||||||
|
* ctx_id = ecore_imf_context_default_id_by_canvas_type_get("evas");
|
||||||
|
* if (ctx_id)
|
||||||
|
* {
|
||||||
|
* imf_context = ecore_imf_context_add(ctx_id);
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
EAPI const Ecore_IMF_Context_Info *ecore_imf_context_info_by_id_get(const char *id);
|
EAPI const Ecore_IMF_Context_Info *ecore_imf_context_info_by_id_get(const char *id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new Input Method Context defined by the given id.
|
||||||
|
*
|
||||||
|
* @param id The Input Method Context id.
|
||||||
|
* @return A newly allocated Input Method Context;
|
||||||
|
* on failure it returns NULL.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI Ecore_IMF_Context *ecore_imf_context_add(const char *id);
|
EAPI Ecore_IMF_Context *ecore_imf_context_add(const char *id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve the info for the given Input Method Context.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return Return a #Ecore_IMF_Context_Info for the given Input Method Context;
|
||||||
|
* on failure it returns NULL.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI const Ecore_IMF_Context_Info *ecore_imf_context_info_get(Ecore_IMF_Context *ctx);
|
EAPI const Ecore_IMF_Context_Info *ecore_imf_context_info_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Delete the given Input Method Context and free its memory.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_del(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_del(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the client window for the Input Method Context; this is the
|
||||||
|
* Ecore_X_Window when using X11, Ecore_Win32_Window when using Win32, etc.
|
||||||
|
* This window is used in order to correctly position status windows, and may
|
||||||
|
* also be used for purposes internal to the Input Method Context.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param window The client window. This may be @c NULL to indicate
|
||||||
|
* that the previous client window no longer exists.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_client_window_set(Ecore_IMF_Context *ctx, void *window);
|
EAPI void ecore_imf_context_client_window_set(Ecore_IMF_Context *ctx, void *window);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the client window of the Input Method Context
|
||||||
|
*
|
||||||
|
* See @ref ecore_imf_context_client_window_set for more details.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return Return the client window.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void *ecore_imf_context_client_window_get(Ecore_IMF_Context *ctx);
|
EAPI void *ecore_imf_context_client_window_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the client canvas for the Input Method Context; this is the
|
||||||
|
* canvas in which the input appears.
|
||||||
|
* The canvas type can be determined by using the context canvas type.
|
||||||
|
* Actually only canvas with type "evas" (Evas *) is supported.
|
||||||
|
* This canvas may be used in order to correctly position status windows, and may
|
||||||
|
* also be used for purposes internal to the Input Method Context.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param canvas The client canvas. This may be @c NULL to indicate
|
||||||
|
* that the previous client canvas no longer exists.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_client_canvas_set(Ecore_IMF_Context *ctx, void *canvas);
|
EAPI void ecore_imf_context_client_canvas_set(Ecore_IMF_Context *ctx, void *canvas);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the client canvas of the Input Method Context.
|
||||||
|
*
|
||||||
|
* See @ref ecore_imf_context_client_canvas_set for more details.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return Return the client canvas.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void *ecore_imf_context_client_canvas_get(Ecore_IMF_Context *ctx);
|
EAPI void *ecore_imf_context_client_canvas_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ask the Input Method Context to show itself.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_show(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_show(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ask the Input Method Context to hide itself.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_hide(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_hide(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve the current preedit string and cursor position
|
||||||
|
* for the Input Method Context.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param str Location to store the retrieved string. The
|
||||||
|
* string retrieved must be freed with free().
|
||||||
|
* @param cursor_pos Location to store position of cursor (in characters)
|
||||||
|
* within the preedit string.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_preedit_string_get(Ecore_IMF_Context *ctx, char **str, int *cursor_pos);
|
EAPI void ecore_imf_context_preedit_string_get(Ecore_IMF_Context *ctx, char **str, int *cursor_pos);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve the current preedit string, attributes and
|
||||||
|
* cursor position for the Input Method Context.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param str Location to store the retrieved string. The
|
||||||
|
* string retrieved must be freed with free().
|
||||||
|
* @param attrs an Eina_List of attributes
|
||||||
|
* @param cursor_pos Location to store position of cursor (in characters)
|
||||||
|
* within the preedit string.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*
|
||||||
|
* Example
|
||||||
|
* @code
|
||||||
|
* char *preedit_string;
|
||||||
|
* int cursor_pos;
|
||||||
|
* Eina_List *attrs = NULL, *l = NULL;
|
||||||
|
* Ecore_IMF_Preedit_Attr *attr;
|
||||||
|
*
|
||||||
|
* ecore_imf_context_preedit_string_with_attributes_get(imf_context,
|
||||||
|
* &preedit_string,
|
||||||
|
* &attrs, &cursor_pos);
|
||||||
|
* if (!preedit_string) return;
|
||||||
|
*
|
||||||
|
* if (strlen(preedit_string) > 0)
|
||||||
|
* {
|
||||||
|
* if (attrs)
|
||||||
|
* {
|
||||||
|
* EINA_LIST_FOREACH(attrs, l, attr)
|
||||||
|
* {
|
||||||
|
* if (attr->preedit_type == ECORE_IMF_PREEDIT_TYPE_SUB1)
|
||||||
|
* {
|
||||||
|
* // Something to do
|
||||||
|
* }
|
||||||
|
* else if (attr->preedit_type == ECORE_IMF_PREEDIT_TYPE_SUB2)
|
||||||
|
* {
|
||||||
|
* // Something to do
|
||||||
|
* }
|
||||||
|
* else if (attr->preedit_type == ECORE_IMF_PREEDIT_TYPE_SUB3)
|
||||||
|
* {
|
||||||
|
* // Something to do
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* // delete attribute list
|
||||||
|
* EINA_LIST_FREE(attrs, attr) free(attr);
|
||||||
|
*
|
||||||
|
* free(preedit_string);
|
||||||
|
* @endcode
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_preedit_string_with_attributes_get(Ecore_IMF_Context *ctx, char **str, Eina_List **attrs, int *cursor_pos);
|
EAPI void ecore_imf_context_preedit_string_with_attributes_get(Ecore_IMF_Context *ctx, char **str, Eina_List **attrs, int *cursor_pos);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Notify the Input Method Context that the widget to which its
|
||||||
|
* correspond has gained focus.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*
|
||||||
|
* Example
|
||||||
|
* @code
|
||||||
|
* static void
|
||||||
|
* _focus_in_cb(void *data, Evas_Object *o, const char *emission, const char *source)
|
||||||
|
* {
|
||||||
|
* ecore_imf_context_reset(imf_context);
|
||||||
|
* ecore_imf_context_focus_in(imf_context);
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* evas_object_event_callback_add(obj, EVAS_CALLBACK_FOCUS_IN, _focus_in_cb, ed);
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_focus_in(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_focus_in(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Notify the Input Method Context that the widget to which its
|
||||||
|
* correspond has lost focus.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*
|
||||||
|
* Example
|
||||||
|
* @code
|
||||||
|
* static void
|
||||||
|
* _focus_out_cb(void *data, Evas_Object *o, const char *emission, const char *source)
|
||||||
|
* {
|
||||||
|
* ecore_imf_context_reset(imf_context);
|
||||||
|
* ecore_imf_context_focus_out(imf_context);
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* evas_object_event_callback_add(obj, EVAS_CALLBACK_FOCUS_OUT, _focus_out_cb, ed);
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_focus_out(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_focus_out(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Notify the Input Method Context that a change such as a
|
||||||
|
* change in cursor position has been made. This will typically
|
||||||
|
* cause the Input Method Context to clear the preedit state.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*
|
||||||
|
* Example
|
||||||
|
* @code
|
||||||
|
* static void
|
||||||
|
* _focus_out_cb(void *data, Evas_Object *o, const char *emission, const char *source)
|
||||||
|
* {
|
||||||
|
* ecore_imf_context_reset(imf_context);
|
||||||
|
* ecore_imf_context_focus_out(imf_context);
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* evas_object_event_callback_add(obj, EVAS_CALLBACK_FOCUS_OUT, _focus_out_cb, ed);
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_reset(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_reset(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Notify the Input Method Context that a change in the cursor
|
||||||
|
* position has been made.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param cursor_pos New cursor position in characters.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_cursor_position_set(Ecore_IMF_Context *ctx, int cursor_pos);
|
EAPI void ecore_imf_context_cursor_position_set(Ecore_IMF_Context *ctx, int cursor_pos);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Notify the Input Method Context that a change in the cursor
|
||||||
|
* location has been made. The location is relative to the canvas.
|
||||||
|
* The cursor location can be used to determine the position of
|
||||||
|
* candidate word window in the immodule.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param x cursor x position.
|
||||||
|
* @param y cursor y position.
|
||||||
|
* @param w cursor width.
|
||||||
|
* @param h cursor height.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_cursor_location_set(Ecore_IMF_Context *ctx, int x, int y, int w, int h);
|
EAPI void ecore_imf_context_cursor_location_set(Ecore_IMF_Context *ctx, int x, int y, int w, int h);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set whether the IM context should use the preedit string
|
||||||
|
* to display feedback. If @c use_preedit is @c EINA_FALSE (default
|
||||||
|
* is @c EINA_TRUE), then the IM context may use some other method to display
|
||||||
|
* feedback, such as displaying it in a child of the root window.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param use_preedit Whether the IM context should use the preedit string.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_use_preedit_set(Ecore_IMF_Context *ctx, Eina_Bool use_preedit);
|
EAPI void ecore_imf_context_use_preedit_set(Ecore_IMF_Context *ctx, Eina_Bool use_preedit);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the callback to be used on surrounding_get request.
|
||||||
|
*
|
||||||
|
* This callback will be called when the Input Method Context
|
||||||
|
* module requests the surrounding context.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param func The callback to be called.
|
||||||
|
* @param data The data pointer to be passed to @p func
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_retrieve_surrounding_callback_set(Ecore_IMF_Context *ctx, Eina_Bool (*func)(void *data, Ecore_IMF_Context *ctx, char **text, int *cursor_pos), const void *data);
|
EAPI void ecore_imf_context_retrieve_surrounding_callback_set(Ecore_IMF_Context *ctx, Eina_Bool (*func)(void *data, Ecore_IMF_Context *ctx, char **text, int *cursor_pos), const void *data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the input mode used by the Ecore Input Context.
|
||||||
|
*
|
||||||
|
* The input mode can be one of the input modes defined in
|
||||||
|
* Ecore_IMF_Input_Mode. The default input mode is
|
||||||
|
* ECORE_IMF_INPUT_MODE_FULL.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param input_mode The input mode to be used by @p ctx.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_mode_set(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Mode input_mode);
|
EAPI void ecore_imf_context_input_mode_set(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Mode input_mode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the input mode being used by the Ecore Input Context.
|
||||||
|
*
|
||||||
|
* See @ref ecore_imf_context_input_mode_set for more details.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return The input mode being used by @p ctx.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*/
|
||||||
EAPI Ecore_IMF_Input_Mode ecore_imf_context_input_mode_get(Ecore_IMF_Context *ctx);
|
EAPI Ecore_IMF_Input_Mode ecore_imf_context_input_mode_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allow an Ecore Input Context to internally handle an event.
|
||||||
|
* If this function returns @c EINA_TRUE, then no further processing
|
||||||
|
* should be done for this event.
|
||||||
|
*
|
||||||
|
* Input methods must be able to accept all types of events (simply
|
||||||
|
* returning @c EINA_FALSE if the event was not handled), but there is no
|
||||||
|
* obligation of any events to be submitted to this function.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param type The type of event defined by #Ecore_IMF_Event_Type.
|
||||||
|
* @param event The event itself.
|
||||||
|
* @return @c EINA_TRUE if the event was handled; otherwise @c EINA_FALSE.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
*
|
||||||
|
* Example
|
||||||
|
* @code
|
||||||
|
* static void
|
||||||
|
* _key_down_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
|
||||||
|
* {
|
||||||
|
* Evas_Event_Key_Down *ev = event_info;
|
||||||
|
* if (!ev->keyname) return;
|
||||||
|
*
|
||||||
|
* if (imf_context)
|
||||||
|
* {
|
||||||
|
* Ecore_IMF_Event_Key_Down ecore_ev;
|
||||||
|
* ecore_imf_evas_event_key_down_wrap(ev, &ecore_ev);
|
||||||
|
* if (ecore_imf_context_filter_event(imf_context,
|
||||||
|
* ECORE_IMF_EVENT_KEY_DOWN,
|
||||||
|
* (Ecore_IMF_Event *)&ecore_ev))
|
||||||
|
* return;
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* evas_object_event_callback_add(obj, EVAS_CALLBACK_KEY_DOWN, _key_down_cb, data);
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
EAPI Eina_Bool ecore_imf_context_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type, Ecore_IMF_Event *event);
|
EAPI Eina_Bool ecore_imf_context_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type, Ecore_IMF_Event *event);
|
||||||
|
|
||||||
/* plugin specific functions */
|
/* plugin specific functions */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @defgroup Ecore_IMF_Context_Module_Group Ecore Input Method Context Module Functions
|
||||||
|
* @ingroup Ecore_IMF_Lib_Group
|
||||||
|
*
|
||||||
|
* Functions that should be used by Ecore Input Method Context modules.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new Input Method Context with klass specified by @p ctxc.
|
||||||
|
*
|
||||||
|
* This method should be used by modules implementing the Input
|
||||||
|
* Method Context interface.
|
||||||
|
*
|
||||||
|
* @param ctxc An #Ecore_IMF_Context_Class.
|
||||||
|
* @return A new #Ecore_IMF_Context; on failure it returns NULL.
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
*/
|
||||||
EAPI Ecore_IMF_Context *ecore_imf_context_new(const Ecore_IMF_Context_Class *ctxc);
|
EAPI Ecore_IMF_Context *ecore_imf_context_new(const Ecore_IMF_Context_Class *ctxc);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the Input Method Context specific data.
|
||||||
|
*
|
||||||
|
* Note that this method should be used by modules to set
|
||||||
|
* the Input Method Context specific data and it's not meant to
|
||||||
|
* be used by applications to store application specific data.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param data The Input Method Context specific data.
|
||||||
|
* @return A new #Ecore_IMF_Context; on failure it returns NULL.
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_data_set(Ecore_IMF_Context *ctx, void *data);
|
EAPI void ecore_imf_context_data_set(Ecore_IMF_Context *ctx, void *data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the Input Method Context specific data.
|
||||||
|
*
|
||||||
|
* See @ref ecore_imf_context_data_set for more details.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return The Input Method Context specific data.
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
*/
|
||||||
EAPI void *ecore_imf_context_data_get(Ecore_IMF_Context *ctx);
|
EAPI void *ecore_imf_context_data_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve context around insertion point.
|
||||||
|
* Input methods typically want context in order to constrain input text based on existing text;
|
||||||
|
* this is important for languages such as Thai where only some sequences of characters are allowed.
|
||||||
|
* In addition, the text around the insertion point can be used for supporting autocapital feature.
|
||||||
|
*
|
||||||
|
* This function is implemented by calling the
|
||||||
|
* Ecore_IMF_Context::retrieve_surrounding_func (
|
||||||
|
* set using #ecore_imf_context_retrieve_surrounding_callback_set).
|
||||||
|
*
|
||||||
|
* There is no obligation for a widget to respond to the
|
||||||
|
* retrieve_surrounding_func, so input methods must be prepared
|
||||||
|
* to function without context.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param text Location to store a UTF-8 encoded string of text
|
||||||
|
* holding context around the insertion point.
|
||||||
|
* If the function returns @c EINA_TRUE, then you must free
|
||||||
|
* the result stored in this location with free().
|
||||||
|
* @param cursor_pos Location to store the position in characters of
|
||||||
|
* the insertion cursor within @p text.
|
||||||
|
* @return @c EINA_TRUE if surrounding text was provided; otherwise
|
||||||
|
* @c EINA_FALSE.
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
*/
|
||||||
EAPI Eina_Bool ecore_imf_context_surrounding_get(Ecore_IMF_Context *ctx, char **text, int *cursor_pos);
|
EAPI Eina_Bool ecore_imf_context_surrounding_get(Ecore_IMF_Context *ctx, char **text, int *cursor_pos);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds ECORE_IMF_EVENT_PREEDIT_START to the event queue.
|
||||||
|
*
|
||||||
|
* ECORE_IMF_EVENT_PREEDIT_START should be added when a new preedit sequence starts.
|
||||||
|
* It's asynchronous method to put event to the event queue.
|
||||||
|
* ecore_imf_context_event_callback_call() can be used as synchronous method.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_preedit_start_event_add(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_preedit_start_event_add(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds ECORE_IMF_EVENT_PREEDIT_END to the event queue.
|
||||||
|
*
|
||||||
|
* ECORE_IMF_EVENT_PREEDIT_END should be added when a new preedit sequence has been completed or canceled.
|
||||||
|
* It's asynchronous method to put event to the event queue.
|
||||||
|
* ecore_imf_context_event_callback_call() can be used as synchronous method.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_preedit_end_event_add(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_preedit_end_event_add(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds ECORE_IMF_EVENT_PREEDIT_CHANGED to the event queue.
|
||||||
|
*
|
||||||
|
* It's asynchronous method to put event to the event queue.
|
||||||
|
* ecore_imf_context_event_callback_call() can be used as synchronous method.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_preedit_changed_event_add(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_preedit_changed_event_add(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds ECORE_IMF_EVENT_COMMIT to the event queue.
|
||||||
|
*
|
||||||
|
* It's asynchronous method to put event to the event queue.
|
||||||
|
* ecore_imf_context_event_callback_call() can be used as synchronous method.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param str The committed string.
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_commit_event_add(Ecore_IMF_Context *ctx, const char *str);
|
EAPI void ecore_imf_context_commit_event_add(Ecore_IMF_Context *ctx, const char *str);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds ECORE_IMF_EVENT_DELETE_SURROUNDING to the event queue.
|
||||||
|
*
|
||||||
|
* Asks the widget that the input context is attached to to delete characters around the cursor position
|
||||||
|
* by adding the ECORE_IMF_EVENT_DELETE_SURROUNDING to the event queue.
|
||||||
|
* Note that offset and n_chars are in characters not in bytes.
|
||||||
|
*
|
||||||
|
* It's asynchronous method to put ECORE_IMF_EVENT_DELETE_SURROUNDING event to the event queue.
|
||||||
|
* ecore_imf_context_event_callback_call() can be used as synchronous method.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param offset The start offset of surrounding to be deleted.
|
||||||
|
* @param n_chars The number of characters to be deleted.
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_delete_surrounding_event_add(Ecore_IMF_Context *ctx, int offset, int n_chars);
|
EAPI void ecore_imf_context_delete_surrounding_event_add(Ecore_IMF_Context *ctx, int offset, int n_chars);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add (register) a callback function to a given context event.
|
||||||
|
*
|
||||||
|
* This function adds a function callback to the context @p ctx when the
|
||||||
|
* event of type @p type occurs on it. The function pointer is @p
|
||||||
|
* func.
|
||||||
|
*
|
||||||
|
* The event type @p type to trigger the function may be one of
|
||||||
|
* #ECORE_IMF_CALLBACK_PREEDIT_START, #ECORE_IMF_CALLBACK_PREEDIT_END,
|
||||||
|
* #ECORE_IMF_CALLBACK_PREEDIT_CHANGED, #ECORE_IMF_CALLBACK_COMMIT and
|
||||||
|
* #ECORE_IMF_CALLBACK_DELETE_SURROUNDING.
|
||||||
|
*
|
||||||
|
* @param ctx Ecore_IMF_Context to attach a callback to.
|
||||||
|
* @param type The type of event that will trigger the callback
|
||||||
|
* @param func The (callback) function to be called when the event is
|
||||||
|
* triggered
|
||||||
|
* @param data The data pointer to be passed to @p func
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*
|
||||||
|
* Example
|
||||||
|
* @code
|
||||||
|
* static void
|
||||||
|
* _imf_event_commit_cb(void *data, Ecore_IMF_Context *ctx, void *event_info)
|
||||||
|
* {
|
||||||
|
* char *commit_str = event_info;
|
||||||
|
* // something to do
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* ecore_imf_context_event_callback_add(en->imf_context, ECORE_IMF_CALLBACK_COMMIT, _imf_event_commit_cb, data);
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_event_callback_add(Ecore_IMF_Context *ctx, Ecore_IMF_Callback_Type type, Ecore_IMF_Event_Cb func, const void *data);
|
EAPI void ecore_imf_context_event_callback_add(Ecore_IMF_Context *ctx, Ecore_IMF_Callback_Type type, Ecore_IMF_Event_Cb func, const void *data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Delete (unregister) a callback function registered to a given
|
||||||
|
* context event.
|
||||||
|
*
|
||||||
|
* This function removes a function callback from the context @p ctx when the
|
||||||
|
* event of type @p type occurs on it. The function pointer is @p
|
||||||
|
* func.
|
||||||
|
*
|
||||||
|
* @see ecore_imf_context_event_callback_add() for more details
|
||||||
|
*
|
||||||
|
* @param ctx Ecore_IMF_Context to remove a callback from.
|
||||||
|
* @param type The type of event that was triggering the callback
|
||||||
|
* @param func The (callback) function that was to be called when the event was triggered
|
||||||
|
* @return the data pointer
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI void *ecore_imf_context_event_callback_del(Ecore_IMF_Context *ctx, Ecore_IMF_Callback_Type type, Ecore_IMF_Event_Cb func);
|
EAPI void *ecore_imf_context_event_callback_del(Ecore_IMF_Context *ctx, Ecore_IMF_Callback_Type type, Ecore_IMF_Event_Cb func);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Call a given callback on the context @p ctx.
|
||||||
|
*
|
||||||
|
* ecore_imf_context_preedit_start_event_add(), ecore_imf_context_preedit_end_event_add(),
|
||||||
|
* ecore_imf_context_preedit_changed_event_add(), ecore_imf_context_commit_event_add() and
|
||||||
|
* ecore_imf_context_delete_surrounding_event_add() APIs are asynchronous
|
||||||
|
* because those API adds each event to the event queue.
|
||||||
|
*
|
||||||
|
* This API provides the way to call each callback function immediately.
|
||||||
|
*
|
||||||
|
* @param ctx Ecore_IMF_Context.
|
||||||
|
* @param type The type of event that will trigger the callback
|
||||||
|
* @param event_info The pointer to event specific struct or information to
|
||||||
|
* pass to the callback functions registered on this event
|
||||||
|
* @ingroup Ecore_IMF_Context_Module_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_event_callback_call(Ecore_IMF_Context *ctx, Ecore_IMF_Callback_Type type, void *event_info);
|
EAPI void ecore_imf_context_event_callback_call(Ecore_IMF_Context *ctx, Ecore_IMF_Callback_Type type, void *event_info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set whether the IM context should allow to use the text prediction.
|
||||||
|
* If @p prediction is @c EINA_FALSE (default is @c EINA_TRUE), then the IM
|
||||||
|
* context will not display the text prediction window.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param prediction Whether the IM context should allow to use the text prediction.
|
||||||
|
* @note Default value is EINA_TRUE.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_prediction_allow_set(Ecore_IMF_Context *ctx, Eina_Bool prediction);
|
EAPI void ecore_imf_context_prediction_allow_set(Ecore_IMF_Context *ctx, Eina_Bool prediction);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get whether the IM context should allow to use the text prediction.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return @c EINA_TRUE if it allows to use the text prediction, otherwise
|
||||||
|
* @c EINA_FALSE.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI Eina_Bool ecore_imf_context_prediction_allow_get(Ecore_IMF_Context *ctx);
|
EAPI Eina_Bool ecore_imf_context_prediction_allow_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the autocapitalization type on the immodule.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param autocapital_type the autocapitalization type.
|
||||||
|
* @note Default type is ECORE_IMF_AUTOCAPITAL_TYPE_SENTENCE.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_autocapital_type_set(Ecore_IMF_Context *ctx, Ecore_IMF_Autocapital_Type autocapital_type);
|
EAPI void ecore_imf_context_autocapital_type_set(Ecore_IMF_Context *ctx, Ecore_IMF_Autocapital_Type autocapital_type);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the autocapitalization type.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return The autocapital type being used by @p ctx.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI Ecore_IMF_Autocapital_Type ecore_imf_context_autocapital_type_get(Ecore_IMF_Context *ctx);
|
EAPI Ecore_IMF_Autocapital_Type ecore_imf_context_autocapital_type_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ask the Input Method Context to show the control panel of using Input Method.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_control_panel_show(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_control_panel_show(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ask the Input Method Context to hide the control panel of using Input Method.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_control_panel_hide(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_control_panel_hide(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ask the Input Method Context to show the input panel (virtual keyboard).
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_show(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_input_panel_show(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ask the Input Method Context to hide the input panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_hide(Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_input_panel_hide(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the layout of the input panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param layout see #Ecore_IMF_Input_Panel_Layout
|
||||||
|
* @note Default layout type is ECORE_IMF_INPUT_PANEL_LAYOUT_NORMAL.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_layout_set(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Layout layout);
|
EAPI void ecore_imf_context_input_panel_layout_set(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Layout layout);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the layout of the current active input panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return layout see #Ecore_IMF_Input_Panel_Layout
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI Ecore_IMF_Input_Panel_Layout ecore_imf_context_input_panel_layout_get(Ecore_IMF_Context *ctx);
|
EAPI Ecore_IMF_Input_Panel_Layout ecore_imf_context_input_panel_layout_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the language of the input panel.
|
||||||
|
* This API can be used when you want to show the English keyboard.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param lang the language to be set to the input panel.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_language_set(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Lang lang);
|
EAPI void ecore_imf_context_input_panel_language_set(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Lang lang);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the language of the input panel.
|
||||||
|
*
|
||||||
|
* See @ref ecore_imf_context_input_panel_language_set for more details.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return Ecore_IMF_Input_Panel_Lang
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI Ecore_IMF_Input_Panel_Lang ecore_imf_context_input_panel_language_get(Ecore_IMF_Context *ctx);
|
EAPI Ecore_IMF_Input_Panel_Lang ecore_imf_context_input_panel_language_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set whether the Input Method Context should request to show the input panel automatically
|
||||||
|
* when the widget has focus.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param enabled If true, the input panel will be shown when the widget is clicked or has focus.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_enabled_set(Ecore_IMF_Context *ctx, Eina_Bool enable);
|
EAPI void ecore_imf_context_input_panel_enabled_set(Ecore_IMF_Context *ctx, Eina_Bool enable);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get whether the Input Method Context requests to show the input panel automatically.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return Return the attribute to show the input panel automatically
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.1.0
|
||||||
|
*/
|
||||||
EAPI Eina_Bool ecore_imf_context_input_panel_enabled_get(Ecore_IMF_Context *ctx);
|
EAPI Eina_Bool ecore_imf_context_input_panel_enabled_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the input panel-specific data to deliver to the input panel.
|
||||||
|
* This API is used by applications to deliver specific data to the input panel.
|
||||||
|
* The data format MUST be negotiated by both application and the input panel.
|
||||||
|
* The size and format of data are defined by the input panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param data The specific data to be set to the input panel.
|
||||||
|
* @param len the length of data, in bytes, to send to the input panel
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_imdata_set(Ecore_IMF_Context *ctx, const void *data, int len);
|
EAPI void ecore_imf_context_input_panel_imdata_set(Ecore_IMF_Context *ctx, const void *data, int len);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the specific data of the current active input panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param data The specific data to be got from the input panel
|
||||||
|
* @param len The length of data
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_imdata_get(Ecore_IMF_Context *ctx, void *data, int *len);
|
EAPI void ecore_imf_context_input_panel_imdata_get(Ecore_IMF_Context *ctx, void *data, int *len);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the "return" key type. This type is used to set string or icon on the "return" key of the input panel.
|
||||||
|
*
|
||||||
|
* An input panel displays the string or icon associated with this type
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param return_key_type The type of "return" key on the input panel
|
||||||
|
* @note Default type is ECORE_IMF_INPUT_PANEL_RETURN_KEY_TYPE_DEFAULT.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_return_key_type_set(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Return_Key_Type return_key_type);
|
EAPI void ecore_imf_context_input_panel_return_key_type_set(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Return_Key_Type return_key_type);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the "return" key type.
|
||||||
|
*
|
||||||
|
* @see ecore_imf_context_input_panel_return_key_type_set() for more details
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return The type of "return" key on the input panel
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI Ecore_IMF_Input_Panel_Return_Key_Type ecore_imf_context_input_panel_return_key_type_get(Ecore_IMF_Context *ctx);
|
EAPI Ecore_IMF_Input_Panel_Return_Key_Type ecore_imf_context_input_panel_return_key_type_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the return key on the input panel to be disabled.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param disabled The state
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_return_key_disabled_set(Ecore_IMF_Context *ctx, Eina_Bool disabled);
|
EAPI void ecore_imf_context_input_panel_return_key_disabled_set(Ecore_IMF_Context *ctx, Eina_Bool disabled);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get whether the return key on the input panel should be disabled or not.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return @c EINA_TRUE if it should be disabled.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI Eina_Bool ecore_imf_context_input_panel_return_key_disabled_get(Ecore_IMF_Context *ctx);
|
EAPI Eina_Bool ecore_imf_context_input_panel_return_key_disabled_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the caps lock mode on the input panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param mode Turn on caps lock on the input panel if @c EINA_TRUE.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_caps_lock_mode_set(Ecore_IMF_Context *ctx, Eina_Bool mode);
|
EAPI void ecore_imf_context_input_panel_caps_lock_mode_set(Ecore_IMF_Context *ctx, Eina_Bool mode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the caps lock mode on the input panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return @c EINA_TRUE if the caps lock is turned on.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.2.0
|
||||||
|
*/
|
||||||
EAPI Eina_Bool ecore_imf_context_input_panel_caps_lock_mode_get(Ecore_IMF_Context *ctx);
|
EAPI Eina_Bool ecore_imf_context_input_panel_caps_lock_mode_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the position of the current active input panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param x top-left x co-ordinate of the input panel
|
||||||
|
* @param y top-left y co-ordinate of the input panel
|
||||||
|
* @param w width of the input panel
|
||||||
|
* @param h height of the input panel
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.3
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_geometry_get(Ecore_IMF_Context *ctx, int *x, int *y, int *w, int *h);
|
EAPI void ecore_imf_context_input_panel_geometry_get(Ecore_IMF_Context *ctx, int *x, int *y, int *w, int *h);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get state of current active input panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @return The state of input panel.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.3
|
||||||
|
*/
|
||||||
EAPI Ecore_IMF_Input_Panel_State ecore_imf_context_input_panel_state_get(Ecore_IMF_Context *ctx);
|
EAPI Ecore_IMF_Input_Panel_State ecore_imf_context_input_panel_state_get(Ecore_IMF_Context *ctx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Register a callback function which will be called if there is change in input panel state,language,mode etc.
|
||||||
|
* In order to deregister the callback function
|
||||||
|
* Use @ref ecore_imf_context_input_panel_event_callback_del.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context
|
||||||
|
* @param type event type
|
||||||
|
* @param func the callback function
|
||||||
|
* @param data application-input panel specific data.
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.3
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_event_callback_add(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Event type, void (*func) (void *data, Ecore_IMF_Context *ctx, int value), const void *data);
|
EAPI void ecore_imf_context_input_panel_event_callback_add(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Event type, void (*func) (void *data, Ecore_IMF_Context *ctx, int value), const void *data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unregister a callback function which will be called if there is change in input panel state, language, mode etc.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param type An #Ecore_IMF_Input_Panel_Event.
|
||||||
|
* @param func the callback function
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.3
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_event_callback_del(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Event type, void (*func) (void *data, Ecore_IMF_Context *ctx, int value));
|
EAPI void ecore_imf_context_input_panel_event_callback_del(Ecore_IMF_Context *ctx, Ecore_IMF_Input_Panel_Event type, void (*func) (void *data, Ecore_IMF_Context *ctx, int value));
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the current language locale of the input panel.
|
||||||
|
*
|
||||||
|
* ex) fr_FR
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param lang Location to store the retrieved language string. The
|
||||||
|
* string retrieved must be freed with free().
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.3
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_input_panel_language_locale_get(Ecore_IMF_Context *ctx, char **lang);
|
EAPI void ecore_imf_context_input_panel_language_locale_get(Ecore_IMF_Context *ctx, char **lang);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the geometry information of the candidate panel.
|
||||||
|
*
|
||||||
|
* @param ctx An #Ecore_IMF_Context.
|
||||||
|
* @param x top-left x co-ordinate of the candidate panel
|
||||||
|
* @param y top-left y co-ordinate of the candidate panel
|
||||||
|
* @param w width of the candidate panel
|
||||||
|
* @param h height of the candidate panel
|
||||||
|
* @ingroup Ecore_IMF_Context_Group
|
||||||
|
* @since 1.3
|
||||||
|
*/
|
||||||
EAPI void ecore_imf_context_candidate_panel_geometry_get(Ecore_IMF_Context *ctx, int *x, int *y, int *w, int *h);
|
EAPI void ecore_imf_context_candidate_panel_geometry_get(Ecore_IMF_Context *ctx, int *x, int *y, int *w, int *h);
|
||||||
|
|
||||||
/* The following entry points must be exported by each input method module
|
/* The following entry points must be exported by each input method module
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue