1# Input<a name="ZH-CN_TOPIC_0000001124789109"></a> 2 3- [简介](#section11660541593) 4- [目录](#section161941989596) 5 - [接口说明](#section1551164914237) 6 - [使用说明](#section129654513264) 7 - [用例说明](#section129654513265) 8 9- [相关仓](#section1371113476307) 10 11## 简介<a name="section11660541593"></a> 12 13该仓下主要包含Input模块HDI(Hardware Driver Interface)接口定义及其实现,对上层输入服务提供操作input设备的驱动能力接口,HDI接口主要包括如下三大类: 14 15- InputManager:管理输入设备,包括输入设备的打开、关闭、设备列表信息获取等; 16- InputReporter:负责输入事件的上报,包括注册、注销数据上报回调函数等; 17- InputController:提供input设备的业务控制接口,包括获取器件信息及设备类型、设置电源状态等。 18 19**图 1** INPUT模块HDI接口层框架图<a name="fig9489629122818"></a> 20 21 22## 目录<a name="section161941989596"></a> 23 24该仓下源代码目录结构如下所示 25 26``` 27/drivers/peripheral/input 28├── hal # input模块的hal层代码 29│ └── include # input模块hal层内部的头文件 30│ └── src # input模块hal层代码的具体实现 31├── interfaces # input模块对上层服务提供的驱动能力接口 32│ └── include # input模块对外提供的接口定义 33├── test # input模块的测试代码 34│ └── unittest # input模块的单元测试代码 35``` 36 37### 接口说明<a name="section1551164914237"></a> 38 39Input驱动提供给系统服务Input Service可直接调用的驱动能力接口,按照属性分类三类:input设备管理模块、input数据上报模块、input业务控制模块,例如提供输入设备打开及关闭接口、注册设备监听的回调接口、设备信息查询接口、电源状态控制接口等。 40 41提供的部分接口说明如[表1 Input HDI接口列表](#table1513255710559)所示: 42 43**表 1** Input HDI接口列表 44 45<a name="table1513255710559"></a> 46<table><thead align="left"><tr id="row171321857155517"><th class="cellrowborder" align="center" valign="top" width="12.031203120312032%" id="mcps1.2.4.1.1"><p id="p6132957115511"><a name="p6132957115511"></a><a name="p6132957115511"></a>头文件</p> 47</th> 48<th class="cellrowborder" align="center" valign="top" width="66.006600660066%" id="mcps1.2.4.1.2"><p id="p14132125715552"><a name="p14132125715552"></a><a name="p14132125715552"></a>接口名称</p> 49</th> 50<th class="cellrowborder" align="center" valign="top" width="21.96219621962196%" id="mcps1.2.4.1.3"><p id="p18132205755516"><a name="p18132205755516"></a><a name="p18132205755516"></a>功能描述</p> 51</th> 52</tr> 53</thead> 54<tbody><tr id="row13132357165514"><td class="cellrowborder" rowspan="4" align="left" valign="top" width="12.031203120312032%" headers="mcps1.2.4.1.1 "><p id="p15674038913"><a name="p15674038913"></a><a name="p15674038913"></a></p> 55<p id="p825185015460"><a name="p825185015460"></a><a name="p825185015460"></a>input_manager.h</p> 56<p id="p2133757135510"><a name="p2133757135510"></a><a name="p2133757135510"></a></p> 57</td> 58<td class="cellrowborder" valign="top" width="66.006600660066%" headers="mcps1.2.4.1.2 "><p id="p11132857135517"><a name="p11132857135517"></a><a name="p11132857135517"></a>int32_t (*OpenInputDevice)(uint32_t devIndex);</p> 59</td> 60<td class="cellrowborder" align="center" valign="top" width="21.96219621962196%" headers="mcps1.2.4.1.3 "><p id="p8233134675314"><a name="p8233134675314"></a><a name="p8233134675314"></a>打开input设备</p> 61</td> 62</tr> 63<tr id="row9132135715515"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p106067813482"><a name="p106067813482"></a><a name="p106067813482"></a>int32_t (*CloseInputDevice)(uint32_t devIndex);</p> 64</td> 65<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p8233144617532"><a name="p8233144617532"></a><a name="p8233144617532"></a>关闭input设备</p> 66</td> 67</tr> 68<tr id="row2973185044814"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p1974125024812"><a name="p1974125024812"></a><a name="p1974125024812"></a>int32_t (*GetInputDevice)(uint32_t devIndex, DeviceInfo **devInfo);</p> 69</td> 70<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p152331046155310"><a name="p152331046155310"></a><a name="p152331046155310"></a>获取指定ID的设备信息</p> 71</td> 72</tr> 73<tr id="row171330575555"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p913315573557"><a name="p913315573557"></a><a name="p913315573557"></a>int32_t (*GetInputDeviceList)(uint32_t *devNum, DeviceInfo **devList, uint32_t size);</p> 74</td> 75<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p1523319466539"><a name="p1523319466539"></a><a name="p1523319466539"></a>获取所有设备列表信息</p> 76</td> 77</tr> 78<tr id="row1513316577554"><td class="cellrowborder" rowspan="3" align="left" valign="top" width="12.031203120312032%" headers="mcps1.2.4.1.1 "><p id="p14171441118"><a name="p14171441118"></a><a name="p14171441118"></a></p> 79<p id="p57063567463"><a name="p57063567463"></a><a name="p57063567463"></a>input_reporter.h</p> 80</td> 81<td class="cellrowborder" valign="top" width="66.006600660066%" headers="mcps1.2.4.1.2 "><p id="p14794193010499"><a name="p14794193010499"></a><a name="p14794193010499"></a>int32_t (*RegisterReportCallback)(uint32_t devIndex, InputReportEventCb *callback);</p> 82</td> 83<td class="cellrowborder" align="center" valign="top" width="21.96219621962196%" headers="mcps1.2.4.1.3 "><p id="p72331046145316"><a name="p72331046145316"></a><a name="p72331046145316"></a>注册input设备的回调</p> 84</td> 85</tr> 86<tr id="row171331657185514"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p123921240124910"><a name="p123921240124910"></a><a name="p123921240124910"></a>int32_t (*UnregisterReportCallback)(uint32_t devIndex);</p> 87</td> 88<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p19233174675311"><a name="p19233174675311"></a><a name="p19233174675311"></a>注销input设备的回调</p> 89</td> 90</tr> 91<tr id="row41331557165518"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p11499124705012"><a name="p11499124705012"></a><a name="p11499124705012"></a>void (*ReportEventPkgCallback)(const EventPackage **pkgs, uint32_t count);</p> 92</td> 93<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p52331246135315"><a name="p52331246135315"></a><a name="p52331246135315"></a>上报数据的回调函数</p> 94</td> 95</tr> 96<tr id="row1452521025813"><td class="cellrowborder" rowspan="9" align="left" valign="top" width="12.031203120312032%" headers="mcps1.2.4.1.1 "><p id="p1285144710118"><a name="p1285144710118"></a><a name="p1285144710118"></a></p> 97<p id="p854114711117"><a name="p854114711117"></a><a name="p854114711117"></a></p> 98<p id="p15741647517"><a name="p15741647517"></a><a name="p15741647517"></a></p> 99<p id="p7909447418"><a name="p7909447418"></a><a name="p7909447418"></a></p> 100<p id="p12525910165811"><a name="p12525910165811"></a><a name="p12525910165811"></a>input_controller.h</p> 101<p id="p942322013262"><a name="p942322013262"></a><a name="p942322013262"></a></p> 102<p id="p1040515339526"><a name="p1040515339526"></a><a name="p1040515339526"></a></p> 103<p id="p19405533115216"><a name="p19405533115216"></a><a name="p19405533115216"></a></p> 104</td> 105<td class="cellrowborder" valign="top" width="66.006600660066%" headers="mcps1.2.4.1.2 "><p id="p14402132815113"><a name="p14402132815113"></a><a name="p14402132815113"></a>int32_t (*SetPowerStatus)(uint32_t devIndex, uint32_t status);</p> 106</td> 107<td class="cellrowborder" align="center" valign="top" width="21.96219621962196%" headers="mcps1.2.4.1.3 "><p id="p1510016065413"><a name="p1510016065413"></a><a name="p1510016065413"></a>设置电源状态</p> 108</td> 109</tr> 110<tr id="row172902161193"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p2062643555111"><a name="p2062643555111"></a><a name="p2062643555111"></a>int32_t (*GetPowerStatus)(uint32_t devIndex, uint32_t *status);</p> 111</td> 112<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p1323394615539"><a name="p1323394615539"></a><a name="p1323394615539"></a>获取电源状态</p> 113</td> 114</tr> 115<tr id="row1948179195"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p8207194414510"><a name="p8207194414510"></a><a name="p8207194414510"></a>int32_t (*GetDeviceType)(uint32_t devIndex, uint32_t *deviceType);</p> 116</td> 117<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p18233154655317"><a name="p18233154655317"></a><a name="p18233154655317"></a>获取设备类型</p> 118</td> 119</tr> 120<tr id="row1331121813197"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p1321125217514"><a name="p1321125217514"></a><a name="p1321125217514"></a>int32_t (*GetChipInfo)(uint32_t devIndex, char *chipInfo, uint32_t length);</p> 121</td> 122<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p14233104614536"><a name="p14233104614536"></a><a name="p14233104614536"></a>获取器件编码信息</p> 123</td> 124</tr> 125<tr id="row1393181951920"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p79410191191"><a name="p79410191191"></a><a name="p79410191191"></a>int32_t (*GetVendorName)(uint32_t devIndex, char *vendorName, uint32_t length);</p> 126</td> 127<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p7233124695317"><a name="p7233124695317"></a><a name="p7233124695317"></a>获取模组厂商名</p> 128</td> 129</tr> 130<tr id="row8960121911198"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p17712110185218"><a name="p17712110185218"></a><a name="p17712110185218"></a>int32_t (*GetChipName)(uint32_t devIndex, char *chipName, uint32_t length);</p> 131</td> 132<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p923316468539"><a name="p923316468539"></a><a name="p923316468539"></a>获取芯片厂商名</p> 133</td> 134</tr> 135<tr id="row10812112081919"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p20738171735219"><a name="p20738171735219"></a><a name="p20738171735219"></a>int32_t (*SetGestureMode)(uint32_t devIndex, uint32_t gestureMode);</p> 136</td> 137<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p5233546175310"><a name="p5233546175310"></a><a name="p5233546175310"></a>设置手势模式</p> 138</td> 139</tr> 140<tr id="row12422102092613"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p56701925155215"><a name="p56701925155215"></a><a name="p56701925155215"></a>int32_t (*RunCapacitanceTest)(uint32_t devIndex, uint32_t testType, char *result, uint32_t length);</p> 141</td> 142<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p13234346125310"><a name="p13234346125310"></a><a name="p13234346125310"></a>执行容值自检测试</p> 143</td> 144</tr> 145<tr id="row124041233155211"><td class="cellrowborder" valign="top" headers="mcps1.2.4.1.1 "><p id="p16405113375215"><a name="p16405113375215"></a><a name="p16405113375215"></a>int32_t (*RunExtraCommand)(uint32_t devIndex, InputExtraCmd *cmd);</p> 146</td> 147<td class="cellrowborder" align="center" valign="top" headers="mcps1.2.4.1.2 "><p id="p192341246185314"><a name="p192341246185314"></a><a name="p192341246185314"></a>执行拓展指令</p> 148</td> 149</tr> 150</tbody> 151</table> 152 153### 使用说明<a name="section129654513264"></a> 154 155该仓核心功能是提供Input驱动能力接口供上层输入系统服务调用,提供的驱动能力接口统一归属为HDI接口层。 156 157通过如下简要示例代码说明Input HDI接口的使用: 158 159``` 160#include "input_manager.h" 161#define DEV_INDEX 1 162 163IInputInterface *g_inputInterface; 164InputReportEventCb g_callback; 165 166/* 定义数据上报的回调函数 */ 167static void ReportEventPkgCallback(const EventPackage **pkgs, uint32_t count) 168{ 169 if (pkgs == NULL || count > MAX_PKG_NUM) { 170 return; 171 } 172 for (uint32_t i = 0; i < count; i++) { 173 HDF_LOGI("%s: pkgs[%d] = 0x%x, 0x%x, %d", __func__, i, pkgs[i]->type, pkgs[i]->code, pkgs[i]->value); 174 } 175} 176 177int InputServiceSample(void) 178{ 179 uint32_t devType = INIT_DEFAULT_VALUE; 180 181 /* 获取Input驱动能力接口 */ 182 int ret = GetInputInterface(&g_inputInterface); 183 if (ret != INPUT_SUCCESS) { 184 HDF_LOGE("%s: get input interfaces failed, ret = %d", __func__, ret); 185 return ret; 186 } 187 188 INPUT_CHECK_NULL_POINTER(g_inputInterface, INPUT_NULL_PTR); 189 INPUT_CHECK_NULL_POINTER(g_inputInterface->iInputManager, INPUT_NULL_PTR); 190 /* 打开特定的input设备 */ 191 ret = g_inputInterface->iInputManager->OpenInputDevice(DEV_INDEX); 192 if (ret) { 193 HDF_LOGE("%s: open input device failed, ret = %d", __func__, ret); 194 return ret; 195 } 196 197 INPUT_CHECK_NULL_POINTER(g_inputInterface->iInputController, INPUT_NULL_PTR); 198 /* 获取对应input设备的类型 */ 199 ret = g_inputInterface->iInputController->GetDeviceType(DEV_INDEX, &devType); 200 if (ret) { 201 HDF_LOGE("%s: get device type failed, ret: %d", __FUNCTION__, ret); 202 return ret; 203 } 204 HDF_LOGI("%s: device1's type is %u\n", __FUNCTION__, devType); 205 206 /* 给特定的input设备注册数据上报回调函数 */ 207 g_callback.ReportEventPkgCallback = ReportEventPkgCallback; 208 INPUT_CHECK_NULL_POINTER(g_inputInterface->iInputReporter, INPUT_NULL_PTR); 209 ret = g_inputInterface->iInputReporter->RegisterReportCallback(DEV_INDEX, &g_callback); 210 if (ret) { 211 HDF_LOGE("%s: register callback failed, ret: %d", __FUNCTION__, ret); 212 return ret; 213 } 214 HDF_LOGI("%s: wait 10s for testing, pls touch the panel now", __FUNCTION__); 215 OsalMSleep(KEEP_ALIVE_TIME_MS); 216 217 /* 注销特定input设备上的回调函数 */ 218 ret = g_inputInterface->iInputReporter->UnregisterReportCallback(DEV_INDEX); 219 if (ret) { 220 HDF_LOGE("%s: unregister callback failed, ret: %d", __FUNCTION__, ret); 221 return ret; 222 } 223 224 /* 关闭特定的input设备 */ 225 ret = g_inputInterface->iInputManager->CloseInputDevice(DEV_INDEX); 226 if (ret) { 227 HDF_LOGE("%s: close device failed, ret: %d", __FUNCTION__, ret); 228 return ret; 229 } 230 return 0; 231} 232``` 233 234### 用例说明<a name="section129654513265"></a> 235 236执行input相关用例,需要提前插入一个hid设备。 237 238相关用例说明: 239 240* drivers/peripheral/input/test中的用例 241 242* test/xts/hats/hdf/input中的用例 243 244## 相关仓<a name="section1371113476307"></a> 245 246[驱动子系统](https://gitee.com/openharmony/docs/blob/master/zh-cn/readme/%E9%A9%B1%E5%8A%A8%E5%AD%90%E7%B3%BB%E7%BB%9F.md) 247 248[drivers\_framework](https://gitee.com/openharmony/drivers_framework/blob/master/README_zh.md) 249 250[drivers\_adapter](https://gitee.com/openharmony/drivers_adapter/blob/master/README_zh.md) 251 252[drivers\_adapter\_khdf\_linux](https://gitee.com/openharmony/drivers_adapter_khdf_linux/blob/master/README_zh.md) 253 254[drivers\_peripheral](https://gitee.com/openharmony/drivers_peripheral) 255 256