热门标签 | 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);      
}     


推荐阅读
  • 尽管在WPF中工作了一段时间,但在菜单控件的样式设置上遇到了一些基础问题,特别是关于如何正确配置前景色和背景色。 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 本文将深入探讨 Unreal Engine 4 (UE4) 中的距离场技术,包括其原理、实现细节以及在渲染中的应用。距离场技术在现代游戏引擎中用于提高光照和阴影的效果,尤其是在处理复杂几何形状时。文章将结合具体代码示例,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 本文详细介绍了如何在 Ubuntu 14.04 系统上搭建仅使用 CPU 的 Caffe 深度学习框架,包括环境准备、依赖安装及编译过程。 ... [详细]
  • 本文详细介绍了在Luat OS中如何实现C与Lua的混合编程,包括在C环境中运行Lua脚本、封装可被Lua调用的C语言库,以及C与Lua之间的数据交互方法。 ... [详细]
  • 本文探讨了如何在 Spring MVC 框架下,通过自定义注解和拦截器机制来实现细粒度的权限管理功能。 ... [详细]
  • 利用Node.js实现PSD文件的高效切图
    本文介绍了如何通过Node.js及其psd2json模块,快速实现PSD文件的自动化切图过程,以适应项目中频繁的界面更新需求。此方法不仅提高了工作效率,还简化了从设计稿到实际应用的转换流程。 ... [详细]
  • 问题描述现在,不管开发一个多大的系统(至少我现在的部门是这样的),都会带一个日志功能;在实际开发过程中 ... [详细]
  • 本问题涉及在给定的无向图中寻找一个至少包含三个节点的环,该环上的节点不重复,并且环上所有边的长度之和最小。目标是找到并输出这个最小环的具体方案。 ... [详细]
  • 洛谷 P4009 汽车加油行驶问题 解析
    探讨了经典算法题目——汽车加油行驶问题,通过网络流和费用流的视角,深入解析了该问题的解决方案。本文将详细阐述如何利用最短路径算法解决这一问题,并提供详细的代码实现。 ... [详细]
  • 近期尝试从www.hub.sciverse.com网站通过编程手段获取数据时遇到问题,起初尝试使用WebBrowser控件进行数据抓取,但发现使用GET方法翻页时,返回的HTML代码始终相同。进一步探究后了解到,该网站的数据是通过Ajax异步加载的,可通过HTTP查看详细的JSON响应。 ... [详细]
  • 本文探讨了在一个物理隔离的环境中构建数据交换平台所面临的挑战,包括但不限于数据加密、传输监控及确保文件交换的安全性和可靠性。同时,作者结合自身项目经验,分享了项目规划、实施过程中的关键决策及其背后的思考。 ... [详细]
  • 深入理解ArrayList
    本文详细解析了ArrayList的工作原理及其性能特点,包括其内存分配机制和增删查改的操作效率。 ... [详细]
  • PHP面试题精选及答案解析
    本文精选了新浪PHP笔试题及最新的PHP面试题,并提供了详细的答案解析,帮助求职者更好地准备PHP相关的面试。 ... [详细]
  • POJ2263是一个经典的图论问题,涉及寻找从起点到终点的最大载重路径。本文将详细介绍该问题的背景、解题思路及代码实现。 ... [详细]
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社区 版权所有