0

我需要有关如何追踪/解决此问题的想法:

我有一个潜在客户说在 Windows 7 32bit 上我的软件出现了这个错误:

imagelist 无法从流中读取 ImageList 数据

人员提供了以下附加信息:

  • 程序在启用 Areo 主题的情况下工作
  • 程序在经典主题上抛出错误
  • 已安装 IE 11
  • 人员报告在system32文件夹中有 5.82.7601.18837 comctl32.dll,在winsxs文件夹中有 6.10.7601.23039 comctl32.dll

(对于那些不知道的人的快速说明 - 因为 WinXP 两个版本都是默认发布的)

...

该可执行文件是在主题 Windows 10 上使用 XE4 构建的,并且至少可以运行(自己测试)

  • win10/32位
  • win10/64位
  • WinXP/32bit/经典-主题
  • 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>

...

去做

我在文档中注意到 ImageList_WriteEx 的状态是: “您不应该创建一个使用 ILC_COLOR32 的 ILP_DOWNLEVEL 标志编写的图像列表” ......

我不确定在使用“ILC_COLORDDB”作为值的 32 位颜色系统上编译时会发生什么?

我的想法是/是 ILP_DOWNLEVEL 可能会被忽略......因此在被5.x ComCtl32读取时更有可能失败?但是我一直无法在互联网上找到任何描述的此类案例,但是...

此外,我的可执行文件似乎适用于虚拟 Win7-SP1-32bit-16color-classic-themes 配置...

...

去做

发送调试工具以获取/确认comctl32.dll 上加载的实际版本

...

尝试过

我尝试将用户指向带有清单的旧版本,而没有 **compability 部分。那没有任何区别。

4

1 回答 1

-4

默认情况下,Windows 7 上的 ComCtl32 版本是 5.82 而不是 6.x。

常用控制版本

因此,您必须相应地修改您的清单以允许使用与 Windows 7 兼容的 Comctl32 版本。

当然,如果您的应用程序没有使用 ComCtl32 5.82 版中不存在的某些功能。如果是这样,那么您将不得不对其实施一些解决方法,或者只是从您的应用程序的官方支持平台中删除 Windows 7。

于 2018-12-17T14:20:40.850 回答