Ошибка чтения TImageList в Win7 (проблема ComCtl32?) - как и почему это может произойти?
Мне нужны идеи о том, как отследить / решить эту проблему:
У меня есть потенциальный клиент, который заявляет, что в Windows 7 32bit мое программное обеспечение выдает эту ошибку:
imagelist Не удалось прочитать данные ImageList из потока
Человек дал эту дополнительную информацию:
- Программа работает с включенной темой Арео
- Программа выдает ошибку на классическую тему
- IE 11 установлен
- Лица сообщают, что 5.82.7601.18837 comctl32.dll в папке system32 и 6.10.7601.23039 comctl32.dll в папке winsxs
(Быстрое примечание для тех, кто не знает - начиная с WinXP обе версии поставляются по умолчанию)
...
Исполняемый файл построен с использованием XE4 на тематической Windows 10 и, по крайней мере, работает (самостоятельно протестирован)
- win10 / 32bit
- win10 / 64bit
- WinXP / 32bit / классическая тема
- HyperV-Virtual-Win7-SP1/32bit/ классическая тема /16bitcolor
Мой TImagelist установлен на "cdDeviceDependent" (что соответствует ILC_COLORDDB)
...
Это мой манифест, извлеченный из моего исполняемого файла с помощью обозревателя ресурсов:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly manifestVersion="1.0" xmlns="urn:schemas-microsoft-com:asm.v1" xmlns:asmv3="urn:schemas-microsoft-com:asm.v3">
<dependency>
<dependentAssembly>
<assemblyIdentity
type="win32"
name="Microsoft.Windows.Common-Controls"
version="6.0.0.0"
publicKeyToken="6595b64144ccf1df"
language="*"
processorArchitecture="*"
/>
</dependentAssembly>
</dependency>
<trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
<security>
<requestedPrivileges>
<requestedExecutionLevel
level="asInvoker"
uiAccess="false"
/>
</requestedPrivileges>
</security>
</trustInfo>
<compatibility xmlns="urn:schemas-microsoft-com:compatibility.v1">
<application>
<supportedOS Id="{8e0f7a12-bfb3-4fe8-b9a5-48fd50a15a9a}"/>
<supportedOS Id="{1f676c76-80e1-4239-95bb-83d0f6d0da78}"/>
<supportedOS Id="{e2011457-1546-43c5-a5fe-008deee3d3f0}"/>
<supportedOS Id="{35138b9a-5d96-4fbd-8e2d-a2440225f93a}"/>
<supportedOS Id="{4a2f28e3-53b9-4441-ba9c-d69d4a4a6e38}"/>
</application>
</compatibility>
</assembly>
...
СДЕЛАТЬ
В документации я заметил, что для ImageList_WriteEx говорится:"Вы не должны создавать список изображений, который написан с флагом ILP_DOWNLEVEL с ILC_COLOR32"...
Я не уверен, что происходит при компиляции в 32-битной цветовой системе с использованием "ILC_COLORDDB" в качестве значения?
Я думаю / было то, что ILP_DOWNLEVEL можно было бы игнорировать... И, таким образом, более вероятно сбой при чтении 5.x ComCtl32? Но я не смог найти таких случаев, описанных в Интернете, но...
Также кажется, что мой исполняемый файл работает в виртуальной конфигурации Win7-SP1-32bit-16color-classic-themes...
...
СДЕЛАТЬ
Отправить инструмент отладки, чтобы получить / подтвердить актуальную версию, загруженную на comctl32.dll
...
ПЫТАЛСЯ
Я попытался указать пользователю на старую версию с манифестом без раздела ** совместимости. Это не имело никакого значения.
1 ответ
По умолчанию версия ComCtl32 в Windows 7 - 5.82, а не 6.x.
Таким образом, вам придется изменить ваш манифест соответственно, чтобы позволить использовать версию Comctl32, совместимую с Windows 7.
Это, конечно, если ваше приложение не использует какую-либо функцию, которой нет в ComCtl32 версии 5.82. Если это произойдет, вам придется внедрить некоторые обходные пути или просто удалить Windows 7 с официально поддерживаемых платформ для вашего приложения.