热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

VCico替换exe图标不成功

如题替换后用exescope打开看下替换图片部分根本没有图片信息代码如下不知道哪里错误了ICONDIRstID;ICONDIRENTRYstIDE;GRPICONDIR
如题 替换后用exescope打开看下替换图片部分 根本没有图片信息 代码如下 不知道哪里错误了


ICONDIR stID;
ICONDIRENTRY stIDE;
GRPICONDIR stGID;
HANDLE hFile;
DWORD nSize, nGSize, dwReserved;
HANDLE hUpdate;
PBYTE pIcon, pGrpIcon;
BOOL ret;

hFile = CreateFile("D:\\ZN\\ico\\Debug\\zn.ico", GENERIC_READ, NULL, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
if (hFile == INVALID_HANDLE_VALUE)
{
MessageBox("123");
}

ZeroMemory(&stID, sizeof(ICONDIR));
ret = ReadFile(hFile, &stID, sizeof(ICONDIR), &dwReserved, NULL);

ZeroMemory(&stIDE, sizeof(ICONDIRENTRY));
ret = ReadFile(hFile, &stIDE, sizeof(ICONDIRENTRY), &dwReserved, NULL);

nSize = stIDE.dwBytesInRes;
pIcon = (PBYTE)malloc(nSize);
SetFilePointer(hFile, stIDE.dwImageOffset, NULL, FILE_BEGIN);
ret = ReadFile(hFile, (LPVOID)pIcon, nSize, &dwReserved, NULL);



ZeroMemory(&stGID, sizeof(GRPICONDIR));
stGID.idCount = stID.idCount;
stGID.idReserved = 0;
stGID.idType = 1;
CopyMemory(&stGID.idEntries, &stIDE, 12);
stGID.idEntries.nID = 0;

nGSize = sizeof(GRPICONDIR);
pGrpIcon = (PBYTE)malloc(nGSize);
CopyMemory(pGrpIcon, &stGID, nGSize);


hUpdate = BeginUpdateResource("D:\\ZN\\ico\\Debug\\32323.exe", false);
ret = UpdateResource(hUpdate, RT_GROUP_ICON, MAKEINTRESOURCE(1), NULL, (LPVOID)pGrpIcon, nGSize);
ret = UpdateResource(hUpdate, RT_ICON, MAKEINTRESOURCE(1),NULL, (LPVOID)pIcon, nSize);
EndUpdateResource(hUpdate, false);

CloseHandle(hFile);

14 个解决方案

#1


网上这类的代码挺多 基本都是这个样子 不知道错误在哪里  上面用到的三个结构体我就不列出来了 关于图标的     求大神啊!

#2


自己给自己up  看在帖子在相关内容的百度第一条了 求大神帮忙啊!

#3


代码没看~~ 你是不是要更改工程可执行程序exe的图标? 直接到工程目录下,的res资源文件夹里面把你工程名的ico(例:mytest.ico)换成你想要的图标就好。

如果是要代码执行,是不是程序运行是图标在使用其它什么的。。。。。

#4


引用 3 楼  的回复:
代码没看~~ 你是不是要更改工程可执行程序exe的图标? 直接到工程目录下,的res资源文件夹里面把你工程名的ico(例:mytest.ico)换成你想要的图标就好。

如果是要代码执行,是不是程序运行是图标在使用其它什么的。。。。。


额 是要代码执行的亲, 图标没有在使用啊 我也是借鉴的别人的代码 编译通过了 执行后出现的问题 没有替换成功 找了一下午错误了 实在找不出来~

#5


引用 4 楼  的回复:
引用 3 楼 的回复:
代码没看~~ 你是不是要更改工程可执行程序exe的图标? 直接到工程目录下,的res资源文件夹里面把你工程名的ico(例:mytest.ico)换成你想要的图标就好。

如果是要代码执行,是不是程序运行是图标在使用其它什么的。。。。。


额 是要代码执行的亲, 图标没有在使用啊 我也是借鉴的别人的代码 编译通过了 执行后出现的问题 没有替换成功 找了一下午错误……

哈哈~~~  我帮忙顶帖~~ 

#6


自己UPUP  好好学习天天向上 有解决过这个问题的嘛 帮个忙啊 可以加分的!

#7


你难道是要动态更换exe图标吗?
如果你想要的是我下面的那个效果,可以通过几步完成,我成功更换了
1.找到资源视图中的Icon中的IDR_MAINFRAME
2.删除这个资源
3.添加资源,导入Icon选择自己想要的图标
4.更改ID为IDR_MAINFRAM
5.生成程序发现Debug里的exe图标更改了
我改成百度的图标了,像素有限

#8


就是啊,根本不需要这么麻烦,还写代码。
直接把你要的图片导入资源,然后复制像素进你的IDR_MAINFRAME。这个连原来的资源都不用删除。
再编译出来就是你要的图标了。

#9



SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon

要加上上面的代码的,之前遇到过这样的问题...

#10


先查:
hUpdate = BeginUpdateResource("D:\\ZN\\ico\\Debug\\32323.exe", false);
if(hUpdate ==0)
{
DWORD dwErr=GetLastError();
}

#11


“三个结构体”代码上传看看,注意是BYTE对齐的。

#12


给你一个好用的:
http://blog.csdn.net/visualeleven/article/details/5754831
// 第一个参数是将要替换图标的exe文件路径,第二个参数是替换的ico文件路径   
void ReplaceExeIco(LPCTSTR lpszApp, LPCTSTR lpszIco)  
{  
CFile file;  
file.Open(lpszIco, CFile::modeRead);  
LONG lOffset = 0;  
DWORD dwSize = 0;  
DWORD dwBytes = 0;  
CONST BYTE bGroupIcoSize = 0x18;  
BYTE* lpGroupIco = new BYTE[bGroupIcoSize];  
memset(lpGroupIco, 0, bGroupIcoSize);  
file.Read(lpGroupIco, 0x06);  
file.Read(lpGroupIco+0x08, 0x0C);  
memcpy(&dwSize, lpGroupIco+0x10, sizeof(DWORD));  
file.Read(&lOffset, sizeof(lOffset));  
BYTE* lpRes = new BYTE[dwSize];  
memset(lpRes, 0, dwSize);  
file.Seek(lOffset, CFile::begin);  
file.Read(lpRes, dwSize);  

HANDLE hApp = BeginUpdateResource(lpszApp, NULL);  
UpdateResource(hApp, RT_GROUP_ICON, MAKEINTRESOURCE(1), 0, lpGroupIco, bGroupIcoSize);  
UpdateResource(hApp, RT_ICON, MAKEINTRESOURCE(1), 0, lpRes, dwSize);  

EndUpdateResource(hApp, FALSE);  

delete[] lpRes;  
delete[] lpGroupIco;  
file.Close();  
}  

#13


引用 12 楼  的回复:
给你一个好用的:
http://blog.csdn.net/visualeleven/article/details/5754831
// 第一个参数是将要替换图标的exe文件路径,第二个参数是替换的ico文件路径  
void ReplaceExeIco(LPCTSTR lpszApp, LPCTSTR lpszIco)  
{  
CFile file;  
file.Open(l……
额 不是编译时候替换图标啊~不过这个代码还有用些 我找到了个可以实现的代码 贴出来大家共享下把 类似于熊猫烧香 先这样把 结贴了

#14


#include 
#include 

typedef struct tagHEADER      
{      
    WORD idReserved;      
    WORD idType;      
    WORD idCount;      
}HEADER, *LPHEADER;      

typedef struct tagICONDIRENTRY      
{      
    BYTE bWidth;      
    BYTE bHeight;      
    BYTE bColorCount;      
    BYTE bReserved;      
    WORD wPlanes;      
    WORD wBitCount;      
    DWORD dwBytesInRes;      
    DWORD dwImageOffset;      
}ICONDIRENTRY, *LPICONDIRENTRY;      

#pragma pack( push )      
#pragma pack( 2 )      
typedef struct tagGRPICONDIRENTRY      
{      
    BYTE bWidth;      
    BYTE bHeight;      
    BYTE bColorCount;      
    BYTE bReserved;      
    WORD wPlanes;      
    WORD wBitCount;      
    DWORD dwBytesInRes;      
    WORD nID;      
}GRPICONDIRENTRY, *LPGRPICONDIRENTRY;;      

typedef struct tagGRPICONDIR      
{      
    WORD idReserved;      
    WORD idType;      
    WORD idCount;      
    GRPICONDIRENTRY idEntries[1];      
}GRPICONDIR, *LPGRPICONDIR;      
#pragma pack( pop )     
 
 
//.CPP文件中的主要代码:
//view plaincopy to clipboardprint?
void ChangeExeIcon(LPCTSTR lpIconFile, LPCTSTR lpExeName) 
{      
    LPICONDIRENTRY pIconDirEntry(NULL);      
    LPGRPICONDIR pGrpIconDir(NULL);      
    HEADER header;      
    LPBYTE pIconBytes(NULL);      
    HANDLE hIconFile(NULL);      
    DWORD dwRet(0), nSize(0), nGSize(0), dwReserved(0);      
    HANDLE hUpdate(NULL);      
    BOOL ret(FALSE);      
    WORD i(0);      
    
    //打开图标文件      
    hIconFile = CreateFile(lpIconFile, GENERIC_READ, NULL, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);      
    if (hIconFile == INVALID_HANDLE_VALUE)      
    {      
        return;      
    }      
    //读取文件头部信息      
    ret=ReadFile(hIconFile, &header, sizeof(HEADER), &dwReserved, NULL);      
    if (!ret)      
    {      
        CloseHandle(hIconFile);      
        return;      
    }      
    //建立每一个图标的目录信息存放区域      
    pIconDirEntry = (LPICONDIRENTRY)new BYTE[header.idCount*sizeof(ICONDIRENTRY)];      
    if (pIcOnDirEntry==NULL)      
    {      
        CloseHandle(hIconFile);      
        return;      
    }      
    //从Icon文件中读取每一个图标的目录信息      
    ret = ReadFile(hIconFile, pIconDirEntry, header.idCount*sizeof(ICONDIRENTRY), &dwReserved, NULL);      
    if (!ret)      
    {      
        delete[] pIconDirEntry;   
        CloseHandle(hIconFile);      
        return;      
    }      
    //建立EXE文件中RT_GROUP_ICON所需的数据结构存放区域      
    nGSize=sizeof(GRPICONDIR)+header.idCount*sizeof(ICONDIRENTRY);      
    pGrpIcOnDir=(LPGRPICONDIR)new BYTE[nGSize];   
    ZeroMemory(pGrpIconDir, nSize);
    //填充信息,这里相当于一个转换的过程      
    pGrpIconDir->idReserved=header.idReserved;      
    pGrpIconDir->idType=header.idType;      
    pGrpIconDir->idCount=header.idCount;      
    //复制信息并设置每一个图标对应的ID。ID为位置索引号      
    for(i=0;i     {      
        pGrpIconDir->idEntries[i].bWidth=pIconDirEntry[i].bWidth;      
        pGrpIconDir->idEntries[i].bHeight=pIconDirEntry[i].bHeight;      
        pGrpIconDir->idEntries[i].bColorCount=pIconDirEntry[i].bColorCount;      
        pGrpIconDir->idEntries[i].bReserved=pIconDirEntry[i].bReserved;      
        pGrpIconDir->idEntries[i].wPlanes=pIconDirEntry[i].wPlanes;      
        pGrpIconDir->idEntries[i].wBitCount=pIconDirEntry[i].wBitCount;      
        pGrpIconDir->idEntries[i].dwBytesInRes=pIconDirEntry[i].dwBytesInRes;      
        pGrpIconDir->idEntries[i].nID=i+1;    //id  == 0 是 RT_GROUP_ICON 的id,我这里替换的时候出现问题,所以就 + 1 了。  
    }      
    //开始更新EXE中的图标资源,ID定为最小0,如果原来存在0ID的图标信息则被替换为新的。      
    hUpdate = BeginUpdateResource(lpExeName, false);      
    if (hUpdate!=NULL)      
    {      
        HMODULE hMe= 0; // means load from this module

        if (FindResource( hMe, lpExeName, RT_GROUP_ICON))
        {
            //首先更新RT_GROUP_ICON信息       
            ret = UpdateResource(hUpdate, RT_GROUP_ICON, MAKEINTRESOURCE(0), MAKELANGID(LANG_CHINESE, SUBLANG_SYS_DEFAULT), (LPVOID)pGrpIconDir, nGSize);      
            if (!ret)      
            {       
                delete[] pIconDirEntry;
                delete[] pGrpIconDir;  
                CloseHandle(hIconFile);      
                return;      
            }      
        }

        //接着的是每一个Icon的信息存放      
        for(i=0;i         {      
            //Icon的字节数      
            nSize = pIconDirEntry[i].dwBytesInRes;      
            //偏移文件的指针到当前图标的开始处      
            dwRet=SetFilePointer(hIconFile, pIconDirEntry[i].dwImageOffset, NULL, FILE_BEGIN);      
            if (dwRet==INVALID_SET_FILE_POINTER)      
            {      
                break;      
            }      
            //准备pIconBytes来存放文件里的Byte信息用于更新到EXE中。
            
            delete[] pIconBytes;
            
            pIconBytes = new BYTE[nSize];  
            ZeroMemory(pIconBytes, nSize);
            ret = ReadFile(hIconFile, (LPVOID)pIconBytes, nSize, &dwReserved, NULL);      
            if(!ret)      
            {      
                break;      
            }      
            //更新每一个ID对应的RT_ICON信息      
            ret = UpdateResource(hUpdate, RT_ICON, MAKEINTRESOURCE(pGrpIconDir->idEntries[i].nID), MAKELANGID(LANG_CHINESE, SUBLANG_SYS_DEFAULT), (LPVOID)pIconBytes, nSize);      
            if(!ret)      
            {      
                break;      
            } 
        }      
        //结束EXE资源的更新操作      
        if (pIconBytes!=NULL)      
        {      
           delete[] pIconBytes;
        }      

        EndUpdateResource(hUpdate, false);      
    }    
    
    //清理资源并关闭Icon文件,到此更新操作结束!
    SAFE_ARRAY_DELETE(pGrpIconDir); 
    SAFE_ARRAY_DELETE(pIconDirEntry);       
    CloseHandle(hIconFile);      
}     


推荐阅读
  • 本文详细探讨了JavaScript中的作用域链和闭包机制,解释了它们的工作原理及其在实际编程中的应用。通过具体的代码示例,帮助读者更好地理解和掌握这些概念。 ... [详细]
  • Windows 7 64位系统下Redis的安装与PHP Redis扩展配置
    本文详细介绍了在Windows 7 64位操作系统中安装Redis以及配置PHP Redis扩展的方法,包括下载、安装和基本使用步骤。适合对Redis和PHP集成感兴趣的开发人员参考。 ... [详细]
  • 如何使用Ping命令来测试网络连接?当网卡安装和有关参数配置完成后,可以使用ping命令来测试一下网络是否连接成功。以winXP为例1、打开XP下DOS窗口具体操作是点击“开始”菜 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • 深入理解ExtJS:从入门到精通
    本文详细介绍了ExtJS的功能及其在大型企业前端开发中的应用。通过实例和详细的文件结构解析,帮助初学者快速掌握ExtJS的核心概念,并提供实用技巧和最佳实践。 ... [详细]
  • 版本控制工具——Git常用操作(下)
    本文由云+社区发表作者:工程师小熊摘要:上一集我们一起入门学习了git的基本概念和git常用的操作,包括提交和同步代码、使用分支、出现代码冲突的解决办法、紧急保存现场和恢复 ... [详细]
  • JavaScript中的数组是数据集合的核心结构之一,内置了多种实用的方法。掌握这些方法不仅能提高开发效率,还能显著提升代码的质量和可读性。本文将详细介绍数组的创建方式及常见操作方法。 ... [详细]
  • 本文详细介绍了C语言中的基本数据类型,包括整型、浮点型、字符型及其各自的子类型,并探讨了这些类型在不同编译环境下的表现。 ... [详细]
  • C#设计模式学习笔记:观察者模式解析
    本文将探讨观察者模式的基本概念、应用场景及其在C#中的实现方法。通过借鉴《Head First Design Patterns》和维基百科等资源,详细介绍该模式的工作原理,并提供具体代码示例。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 在安装Oracle 11g时,CentOS 6.5系统提示交换空间不足。本文详细介绍了如何通过两种方法增加交换空间,并提供了具体步骤和命令,帮助用户解决这一问题。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • Linux环境下C语言实现定时向文件写入当前时间
    本文介绍如何在Linux系统中使用C语言编程,实现在每秒钟向指定文件中写入当前时间戳。通过此示例,读者可以了解基本的文件操作、时间处理以及循环控制。 ... [详细]
  • 本文详细介绍了一种通过MySQL弱口令漏洞在Windows操作系统上获取SYSTEM权限的方法。该方法涉及使用自定义UDF DLL文件来执行任意命令,从而实现对远程服务器的完全控制。 ... [详细]
author-avatar
手机用户2602889575
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有