# Input Method Framework > ![icon-note.gif](public_sys-resources/icon-note.gif) **NOTE**
The initial APIs of this module are supported since API version 6. Newly added APIs will be marked with a superscript to indicate their earliest API version. > ## Modules to Import ``` import inputMethod from '@ohos.inputMethod'; ``` ## inputMethod8+ Provides the constants. **System capability**: SystemCapability.Miscservices.InputMethodFramework | Name| Type| Readable| Writable| Description| | -------- | -------- | -------- | -------- | -------- | | MAX_TYPE_NUM | number | Yes| No| Maximum number of supported input methods.| ## InputMethodProperty8+ Describes the input method application attributes. **System capability**: SystemCapability.Miscservices.InputMethodFramework | Name| Type| Readable| Writable| Description| | -------- | -------- | -------- | -------- | -------- | | packageName | string | Yes| No| Package name.| | methodId | string | Yes| No| Ability name.| ## inputMethod.getInputMethodController getInputMethodController(): InputMethodController Obtains an [InputMethodController](#InputMethodController) instance. **System capability**: SystemCapability.Miscservices.InputMethodFramework **Return value** | Type| Description| | -------- | -------- | | [InputMethodController](#InputMethodController) | Returns the current **InputMethodController** instance.| **Example** ``` var InputMethodController = inputMethod.getInputMethodController(); ``` ## inputMethod.getInputMethodSetting8+ getInputMethodSetting(): InputMethodSetting Obtains an [InputMethodSetting](#InputMethodSetting) instance. **System capability**: SystemCapability.Miscservices.InputMethodFramework **Return value** | Type | Description | | ----------------------------------------- | ---------------------------- | | [InputMethodSetting](#InputMethodSetting) | Returns the current **InputMethodSetting** instance.| **Example** ```js var InputMethodSetting = inputMethod.getInputMethodSetting(); ``` ## InputMethodController In the following API examples, you must first use [getInputMethodController](#getInputMethodController) to obtain an **InputMethodController** instance, and then call the APIs using the obtained instance. ### stopInput stopInput(callback: AsyncCallback<boolean>): void Hides the keyboard. This API uses an asynchronous callback to return the result. **System capability**: SystemCapability.Miscservices.InputMethodFramework **Parameters** | Name| Type| Mandatory| Description| | -------- | -------- | -------- | -------- | | callback | AsyncCallback<boolean> | Yes| Callback used to return whether the keyboard is successfully hidden.| **Example** ```js InputMethodController.stopInput((error)=>{ console.info('stopInput'); }); ``` ### stopInput stopInput(): Promise<boolean> Hides the keyboard. This API uses an asynchronous callback to return the result. **System capability**: SystemCapability.Miscservices.InputMethodFramework **Return value** | Type| Description| | -------- | -------- | | Promise<boolean> | Promise used to return whether the keyboard is successfully hidden.| **Example** ```js var isSuccess = InputMethodController.stopInput(); console.info('stopInput isSuccess = ' + isSuccess); ``` ## InputMethodSetting8+ In the following API examples, you must first use [getInputMethodSetting](#getInputMethodSetting) to obtain an **InputMethodSetting** instance, and then call the APIs using the obtained instance. ### listInputMethod listInputMethod(callback: AsyncCallback<Array<InputMethodProperty>>): void Obtains the list of installed input methods. This API uses an asynchronous callback to return the result. **System capability**: SystemCapability.Miscservices.InputMethodFramework **Parameters** | Name | Type | Mandatory| Description | | -------- | -------------------------------------------------- | ---- | ---------------------- | | callback | Array<[InputMethodProperty](#InputMethodProperty)> | Yes | Callback used to return the list of installed input methods.| **Example** ```js InputMethodSetting.listInputMethod((properties)=>{ for (var i = 0;i < properties.length; i++) { var property = properties[i]; console.info(property.packageName + "/" + property.methodId); } }); ``` ### listInputMethod listInputMethod(): Array<InputMethodProperty> Obtains the list of installed input methods. This API uses an asynchronous callback to return the result. **System capability**: SystemCapability.Miscservices.InputMethodFramework **Return value** | Type | Description | | ----------------------------------------------------------- | ---------------------- | | Promise> | Promise used to return the list of installed input methods.| **Example** ```js var properties = InputMethodSetting.listInputMethod(); for (var i = 0;i < properties.length; i++) { var property = properties[i]; console.info(property.packageName + "/" + property.methodId); } ``` ### displayOptionalInputMethod displayOptionalInputMethod(callback: AsyncCallback<void>): void Displays a dialog box for selecting an input method. This API uses an asynchronous callback to return the result. **System capability**: SystemCapability.Miscservices.InputMethodFramework - Parameters | Name| Type| Mandatory| Description| | -------- | -------- | -------- | -------- | | callback | AsyncCallback<void> | Yes| Callback used to return the execution result.| **Example** ```js InputMethodSetting.displayOptionalInputMethod(()=>{ console.info('displayOptionalInputMethod is called'); }); ``` ### displayOptionalInputMethod displayOptionalInputMethod(): Promise<void> Displays a dialog box for selecting an input method. This API uses an asynchronous callback to return the result. **System capability**: SystemCapability.Miscservices.InputMethodFramework **Return value** | Type| Description| | -------- | -------- | | Promise<void> | Promise used to return the execution result.| **Example** ```js InputMethodSetting.displayOptionalInputMethod(); ```