android触摸屏idc,Androididc⽂件配置
1.idc是什么?
idc 是Input Device Configuration的缩写,输⼊设备配置⽂件(.idc ⽂件)包含特定设备的配置属性,这些属性会影响输⼊设备的⾏为。
输⼊设备配置⽂件通常并⾮标准外围设备(例如 HID 键盘和⿏标)所必需的,因为默认的系统⾏为通常可确保它们即插即⽤。另⼀⽅⾯,内置的嵌⼊式设备(尤其是触摸屏)⼏乎总是需要输⼊设备配置⽂件来指定其⾏为。
2.idc位置按顺序查阅以下路径。
/odm/usr/idc/Vendor_XXXX_Product_XXXX_Version_XXXX.idc
/vendor/usr/idc/Vendor_XXXX_Product_XXXX_Version_XXXX.idc
/system/usr/idc/Vendor_XXXX_Product_XXXX_Version_XXXX.idc
/data/system/devices/idc/Vendor_XXXX_Product_XXXX_Version_XXXX.idc
/
odm/usr/idc/Vendor_XXXX_Product_XXXX.idc
/vendor/usr/idc/Vendor_XXXX_Product_XXXX.idc
/system/usr/idc/Vendor_XXXX_Product_XXXX.idc
/data/system/devices/idc/Vendor_XXXX_Product_XXXX.idc
/odm/usr/idc/device-name.idc
/vendor/usr/idc/device-name.idc
/system/usr/idc/device-name.idc
/data/system/devices/idc/device-name.idc
当构建包含设备名称的⽂件路径时,设备名称中除“0-9”、“a-z”、“A-Z”、“-”或“_”之外的所有字符将替换为“_”。
3.idc⽂件常⽤配置属性
#=0 外部设备 =1内部设备
device.internal = 0
#定义:keyboard.layout = #指定与输⼊设备关联的键布局⽂件的名称,不包括.kl扩展名。 如果找不到此⽂件,输⼊系统将使⽤默认键布局。
keyboard.layout = qwerty
#定义:keyboard.characterMap = #指定与输⼊设备关联的键字符映射⽂件的名称,不包括.kcm扩展名。 如果找不到此⽂件,输⼊系统将使⽤默认的键字符映射。
#在查找期间,名称中的空格将转换为下划线。
keyboard.characterMap = qwerty
#定义:ientationAware = 0 |1
#指定键盘是否应对显⽰⽅向更改做出反应。
#如果值为1,则在关联的显⽰⽅向改变时旋转⽅向键盘键。
#如果值为0,则键盘不受显⽰⽅向更改的影响。
#默认值为0。
#⽅向感知⽤于⽀持⽅向键盘键的旋转,例如Motorola Droid上的旋转。 例如,当设备从其⾃然⽅向顺时针旋转90度时,
#KEYCODE_DPAD_UP被重新映射以产⽣KEYCODE_DPAD_RIGHT,因为当设备保持在该⽅向时,“向上”键最终指向“右”。
#定义:keyboard.builtIn = 0 |1
#指定键盘是否为内置(物理连接)键盘。
#如果设备名称以-keypad结尾,则默认值为1,否则为0。
#内置键盘的设备ID始终为0.其他⾮内置键盘将分配唯⼀的⾮零设备ID。
#对于内置键盘使⽤id为0对于保持与KeyCharacterMap.BUILT_IN_KEYBOARD字段的兼容性⾮常重要,该字段指定内置键盘的id并且值为0.
#此字段已在API中弃⽤但较旧 应⽤程序可能仍在使⽤它。
#⽆论此属性的设置如何,特殊功能键盘(其键字符映射指定SPECIAL_FUNCTION的类型)将永远不会注册为内置键盘。
#这是因为根据定义,特殊功能键盘不打算⽤于通⽤键⼊。
keyboard.builtIn = 1
4.idc代码流程
Eventhub在打开设备时会读取设备的idc⽂件
->Eventhub.openDeviceLocked->loadConfigurationLocked
void EventHub::loadConfigurationLocked(Device* device) {
device->configurationFile = getInputDeviceConfigurationFilePathByDeviceIdentifier(
device->identifier, INPUT_DEVICE_CONFIGURATION_FILE_TYPE_CONFIGURATION);
if (device->configurationFile.isEmpty()) {
ALOGD("No input device configuration file found for device '%s'.",
device->identifier.name.string());
} el {
status_t status = PropertyMap::load(device->configurationFile,
&device->configuration);
if (status) {
ALOGE("Error loading input device configuration file for device '%s'.? "
"Using default configuration.",
device->identifier.name.string());
}
}
}
idc⽂件的加载顺序如下,如果找到了idc⽂件则直接返回不会再加载后⾯的idc⽂件
Vendor_XXXX_Product_XXXX_Version_XXXX.idc
Vendor_XXXX_Product_XXXX.idc
device-name.idc
String8 getInputDeviceConfigurationFilePathByDeviceIdentifier(
const InputDeviceIdentifier& deviceIdentifier,
InputDeviceConfigurationFileType type) {
if (deviceIdentifier.vendor !=0 && deviceIdentifier.product != 0) {
if (deviceIdentifier.version != 0) {
// Try vendor product version.
String8 versionPath(getInputDeviceConfigurationFilePathByName(
String8::format("Vendor_%04x_Product_%04x_Version_%04x", deviceIdentifier.vendor, deviceIdentifier.product,
deviceIdentifier.version),
type));
if (!versionPath.isEmpty()) {
return versionPath;
}
}
// Try vendor product.
String8 productPath(getInputDeviceConfigurationFilePathByName(
String8::format("Vendor_%04x_Product_%04x",
deviceIdentifier.vendor, deviceIdentifier.product),
type));
if (!productPath.isEmpty()) {
return productPath;
}
}
// Try device name.
return getInputDeviceConfigurationFilePathByName(deviceIdentifier.name, type); }
String8 getInputDeviceConfigurationFilePathByName(
const String8& name, InputDeviceConfigurationFileType type) {
// Search system repository.
String8 path;
path.tTo(getenv("ANDROID_ROOT"));
path.append("/usr/");
appendInputDeviceConfigurationFileRelativePath(path, name, type);
#if DEBUG_PROBE
ALOGD("Probing for system provided input device configuration file: path='%s'", path.string()); #endif
if (!access(path.string(), R_OK)) {
#if DEBUG_PROBE
ALOGD("Found");
#endif
return path;
}
// Search ur repository.
// TODO Should only look here if not in safe mode.
path.tTo(getenv("ANDROID_DATA"));
path.append("/system/devices/");
appendInputDeviceConfigurationFileRelativePath(path, name, type);
#if DEBUG_PROBE
ALOGD("Probing for system ur input device configuration file: path='%s'", path.string());
#endif
if (!access(path.string(), R_OK)) {
#if DEBUG_PROBE
ALOGD("Found");
#endif
return path;
}
// Not found.
#if DEBUG_PROBE
ALOGD("Probe failed to find input device configuration file: name='%s', type=%d",
name.string(), type);
#endif
return String8();
}
参考博客: