Ошибка чтения TImageList в Win7 (проблема ComCtl32?) - как и почему это может произойти? - PullRequest
0 голосов
/ 16 декабря 2018

Мне нужны идеи о том, как отследить / решить эту проблему:

У меня есть потенциальный клиент, который заявляет, что в Windows 7 32bit мое программное обеспечение выдает эту ошибку:

imagelist Не удалось прочитать данные ImageList из потока

Пользователь предоставил эту дополнительную информацию:

  • Программа работает с включенной темой Areo
  • Программа выдаетошибка в классической теме
  • Установлен 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 / classic-theme
  • HyperV-Virtual-Win7-SP1 / 32bit / classic-theme / 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>

...

TODO

Я заметил в документации, что для ImageList_WriteEx это состояния: "Вы не должны создавать список изображений, который пишется с флагом ILP_DOWNLEVEL с ILC_COLOR32" ...

Я не уверен, что происходит при компиляции в 32-битной системе цветов с использованием "ILC_COLORDDB"как значение?

Я думаю / было ли то, что ILP_DOWNLEVEL можно было бы игнорировать ... И, таким образом, более вероятно, что он потерпит неудачу при чтении 5.x ComCtl32 ?Но я не смог найти ни одного подобного случая, описанного в Интернете, но ...

Также, похоже, мой исполняемый файл работает в виртуальной конфигурации Win7-SP1-32bit-16color-classic-themes ...

...

TODO

Отправить инструмент отладки для получения / подтверждения фактической версии, загруженной на comctl32.dll

...

TRIED

Я пытался указать пользователю старую версию с манифестом без ** раздела совместимости.Это не имело никакого значения.

1 Ответ

0 голосов
/ 17 декабря 2018

По умолчанию версия ComCtl32 в Windows 7 - 5.82, а не 6.x.

Версии общего управления

Таким образом, вам придется соответствующим образом изменить манифест, чтобы разрешить использование версии Comctl32, совместимой с Windows 7.

Это, конечно,если ваше приложение не использует какую-либо функцию, которой нет в ComCtl32 версии 5.82.Если это произойдет, вам придется внедрить некоторые обходные пути или просто удалить Windows 7 с официально поддерживаемых платформ для вашего приложения.

...