После долгих проб и ошибок я получил очень хакерское решение для работы:
Я добавил spannables с таким же удвоенным размером текста, как выделенное слово, к каждому пробелу внутри текста. , Таким образом, весь TextView получил одинаковый (большой) межстрочный интервал. Имейте в виду, что вы не можете повторно использовать spannable.
Затем я дал TextView отрицательный lineSpacingExtra, чтобы межстрочный интервал снова выглядел хорошо.
Чтобы избежать неестественно больших пробелов из-за увеличенного размера текста, я добавил ScaleXSpan к каждому пробелу, масштабируя их до 50% от их первоначального большого размера.
Этот метод должен работать даже для TextViews, которые содержат локализованные строки (где вы никогда не знаете, в каком положении появляется выделенное слово или какова длина вашей строки), если в каждой строке содержится хотя бы один пробел.
Кажется, вам нужно либо указать флаг DIGCF_ALLCLASSES
, чтобы найти все классы, соответствующие данному идентификатору экземпляра устройства, либо указать ClassGuid и использовать Флаг DIGCF_DEFAULT
.
Это сработало для меня:
void error(DWORD err)
{
WCHAR buf[0x200];
FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM, NULL, err, 0, buf, 0x200, NULL);
wprintf(L"%x: %s\n", err, buf);
}
int _tmain(int argc, _TCHAR* argv[])
{
PCWSTR devinst = L"HID\\VID_413C&PID_2105\\6&22CE0F66&0&0000";
HDEVINFO hinfo = SetupDiGetClassDevs(NULL, devinst, NULL, DIGCF_DEVICEINTERFACE | DIGCF_ALLCLASSES);
if (hinfo == INVALID_HANDLE_VALUE)
{
error(GetLastError());
return 1;
}
SP_DEVINFO_DATA dinfo;
dinfo.cbSize = sizeof(dinfo);
int ix = 0;
while (SetupDiEnumDeviceInfo(hinfo, ix++, &dinfo))
{
wprintf(L"Match\n");
}
error(GetLastError());
SetupDiDestroyDeviceInfoList(hinfo);
return 0;
}
С выводом:
Match
103: No more data is available.