有四个类名叫part1-pic-bg的盒子。id分别是part1-iconinfo1,part1-iconinfo2,part1-iconinfo3,part1-iconinfo4,在这个大盒子里面分别有一个类名叫part1-iconinfo的小盒子,,id值分别叫part1-iconinfo1-content,part1-iconinfo2-content,part1-iconinfo3-content,part1-iconinfo4-content,最初类名叫part1-iconinfo的盒子是隐藏状态,当点击大盒子的时候,对应的显示各自的小盒子,再次点击任意地方可以隐藏小盒子的jquery代码

时间: 2024-02-03 12:12:08 浏览: 19
可以使用以下代码实现: ``` $(document).ready(function() { $('.part1-pic-bg').click(function() { var id = $(this).attr('id'); $('#' + id + '-content').toggle(); }); $(document).click(function(event) { if(!$(event.target).closest('.part1-pic-bg').length) { $('.part1-iconinfo').hide(); } }); }); ``` 首先,当用户点击 `.part1-pic-bg` 盒子时,获取其 id 值并在该 id 后面添加 `-content`,得到对应的小盒子的 id 值,然后使用 `toggle()` 函数来显示或隐藏该小盒子。 其次,当用户点击页面中其他地方时,检查是否点击了 `.part1-pic-bg` 盒子或其内部元素,如果没有,则隐藏所有小盒子。
相关问题

我需要在windows下正确的获取word文档“1.docx”的图标原始二进制资源数据,请告诉我详细C语言代码

获取Word文档的图标原始二进制资源数据,可以通过以下步骤完成: 1. 使用Win32 API函数LoadLibraryEx加载shell32.dll库。 2. 使用Win32 API函数LoadIconMetric从shell32.dll库中加载Word文档的图标。 3. 使用Win32 API函数GetIconInfo获取图标的信息。 4. 使用Win32 API函数GetDIBits获取图标的位图信息。 5. 使用Win32 API函数FreeLibrary释放shell32.dll库。 下面是详细的C语言代码: ```c #include <Windows.h> #include <Shellapi.h> #include <Shlwapi.h> #pragma comment(lib, "Shell32.lib") #pragma comment(lib, "Shlwapi.lib") int main() { HMODULE hModule = LoadLibraryEx("shell32.dll", NULL, LOAD_LIBRARY_AS_DATAFILE); if (hModule == NULL) { return 0; } HICON hIcon; HRESULT hr = LoadIconMetric(hModule, MAKEINTRESOURCE(2), LIM_LARGE, &hIcon); if (FAILED(hr)) { FreeLibrary(hModule); return 0; } ICONINFO iconInfo; if (!GetIconInfo(hIcon, &iconInfo)) { DestroyIcon(hIcon); FreeLibrary(hModule); return 0; } BITMAP bmp; if (!GetObject(iconInfo.hbmColor, sizeof(BITMAP), &bmp)) { DeleteObject(iconInfo.hbmColor); DeleteObject(iconInfo.hbmMask); DestroyIcon(hIcon); FreeLibrary(hModule); return 0; } BITMAPINFOHEADER bmpInfoHeader; bmpInfoHeader.biSize = sizeof(BITMAPINFOHEADER); bmpInfoHeader.biWidth = bmp.bmWidth; bmpInfoHeader.biHeight = bmp.bmHeight; bmpInfoHeader.biPlanes = bmp.bmPlanes; bmpInfoHeader.biBitCount = bmp.bmBitsPixel; bmpInfoHeader.biCompression = BI_RGB; bmpInfoHeader.biSizeImage = bmp.bmWidthBytes * bmp.bmHeight; bmpInfoHeader.biXPelsPerMeter = 0; bmpInfoHeader.biYPelsPerMeter = 0; bmpInfoHeader.biClrUsed = 0; bmpInfoHeader.biClrImportant = 0; LPVOID lpBits = NULL; HDC hdc = GetDC(NULL); HBITMAP hBitmap = CreateDIBSection(hdc, (BITMAPINFO*)&bmpInfoHeader, DIB_RGB_COLORS, &lpBits, NULL, 0); ReleaseDC(NULL, hdc); if (hBitmap != NULL) { HDC hMemDC = CreateCompatibleDC(NULL); HBITMAP hOldBitmap = (HBITMAP)SelectObject(hMemDC, hBitmap); if (!GetDIBits(hMemDC, iconInfo.hbmColor, 0, bmp.bmHeight, lpBits, (BITMAPINFO*)&bmpInfoHeader, DIB_RGB_COLORS)) { DeleteDC(hMemDC); DeleteObject(hBitmap); DeleteObject(iconInfo.hbmColor); DeleteObject(iconInfo.hbmMask); DestroyIcon(hIcon); FreeLibrary(hModule); return 0; } SelectObject(hMemDC, hOldBitmap); DeleteDC(hMemDC); DeleteObject(hBitmap); } DeleteObject(iconInfo.hbmColor); DeleteObject(iconInfo.hbmMask); DestroyIcon(hIcon); FreeLibrary(hModule); return 0; } ``` 在上面的代码中,我们使用了LoadLibraryEx、LoadIconMetric、GetIconInfo、GetDIBits、FreeLibrary等Win32 API函数来获取Word文档的图标原始二进制资源数据。请注意,这里的资源ID是2,如果要获取其他类型的文件图标,请查看相应的资源ID。

Win32 输入exe路径和exe资源id和图标路径,替换exe图标,实现函数

以下是一个实现这个功能的示例函数: ```c++ #include <Windows.h> #include <Shlwapi.h> #pragma comment(lib, "Shlwapi.lib") BOOL ReplaceExeIcon(LPCTSTR lpExePath, DWORD dwIconResourceId, LPCTSTR lpNewIconPath) { // 读取exe文件的文件头信息 HANDLE hFile = CreateFile(lpExePath, GENERIC_READ | GENERIC_WRITE, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); if (hFile == INVALID_HANDLE_VALUE) { return FALSE; } IMAGE_DOS_HEADER dosHeader; DWORD dwBytesRead; if (!ReadFile(hFile, &dosHeader, sizeof(dosHeader), &dwBytesRead, NULL) || dwBytesRead != sizeof(dosHeader)) { CloseHandle(hFile); return FALSE; } SetFilePointer(hFile, dosHeader.e_lfanew + sizeof(DWORD), NULL, FILE_BEGIN); IMAGE_FILE_HEADER fileHeader; if (!ReadFile(hFile, &fileHeader, sizeof(fileHeader), &dwBytesRead, NULL) || dwBytesRead != sizeof(fileHeader)) { CloseHandle(hFile); return FALSE; } // 根据exe文件头信息找到资源表位置 DWORD dwResourceOffset = dosHeader.e_lfanew + sizeof(DWORD) + sizeof(IMAGE_FILE_HEADER) + fileHeader.SizeOfOptionalHeader; SetFilePointer(hFile, dwResourceOffset, NULL, FILE_BEGIN); IMAGE_RESOURCE_DIRECTORY resourceDirectory; if (!ReadFile(hFile, &resourceDirectory, sizeof(resourceDirectory), &dwBytesRead, NULL) || dwBytesRead != sizeof(resourceDirectory)) { CloseHandle(hFile); return FALSE; } // 遍历资源表,找到指定的图标资源 IMAGE_RESOURCE_DIRECTORY_ENTRY* pEntry = (IMAGE_RESOURCE_DIRECTORY_ENTRY*)((BYTE*)&resourceDirectory + sizeof(resourceDirectory)); for (WORD i = 0; i < resourceDirectory.NumberOfNamedEntries + resourceDirectory.NumberOfIdEntries; i++, pEntry++) { if (pEntry->u1.s1.Id == (WORD)RT_GROUP_ICON) { // 找到了图标资源组,进入下一层资源表 DWORD dwNextOffset = dwResourceOffset + pEntry->u2.s2.OffsetToDirectory; SetFilePointer(hFile, dwNextOffset, NULL, FILE_BEGIN); IMAGE_RESOURCE_DIRECTORY nextResourceDirectory; if (!ReadFile(hFile, &nextResourceDirectory, sizeof(nextResourceDirectory), &dwBytesRead, NULL) || dwBytesRead != sizeof(nextResourceDirectory)) { CloseHandle(hFile); return FALSE; } IMAGE_RESOURCE_DIRECTORY_ENTRY* pNextEntry = (IMAGE_RESOURCE_DIRECTORY_ENTRY*)((BYTE*)&nextResourceDirectory + sizeof(nextResourceDirectory)); for (WORD j = 0; j < nextResourceDirectory.NumberOfNamedEntries + nextResourceDirectory.NumberOfIdEntries; j++, pNextEntry++) { if (pNextEntry->u1.s1.Id == dwIconResourceId) { // 找到了指定的图标资源 DWORD dwIconOffset = dwResourceOffset + pNextEntry->u2.s2.OffsetToData; SetFilePointer(hFile, dwIconOffset, NULL, FILE_BEGIN); IMAGE_RESOURCE_DATA_ENTRY dataEntry; if (!ReadFile(hFile, &dataEntry, sizeof(dataEntry), &dwBytesRead, NULL) || dwBytesRead != sizeof(dataEntry)) { CloseHandle(hFile); return FALSE; } // 读取图标资源 BYTE* pIconData = new BYTE[dataEntry.Size]; if (!ReadFile(hFile, pIconData, dataEntry.Size, &dwBytesRead, NULL) || dwBytesRead != dataEntry.Size) { delete[] pIconData; CloseHandle(hFile); return FALSE; } // 替换图标资源 HANDLE hNewIcon = LoadImage(NULL, lpNewIconPath, IMAGE_ICON, 0, 0, LR_DEFAULTSIZE | LR_LOADFROMFILE); if (hNewIcon == NULL) { delete[] pIconData; CloseHandle(hFile); return FALSE; } ICONINFO iconInfo; if (!GetIconInfo((HICON)hNewIcon, &iconInfo)) { delete[] pIconData; CloseHandle(hFile); DestroyIcon((HICON)hNewIcon); return FALSE; } DWORD dwNewIconSize = iconInfo.dwBytesInRes; BYTE* pNewIconData = new BYTE[dwNewIconSize]; if (!GetIconResourceData(iconInfo.hResInfo, pNewIconData, dwNewIconSize)) { delete[] pIconData; delete[] pNewIconData; CloseHandle(hFile); DestroyIcon((HICON)hNewIcon); return FALSE; } memcpy(pIconData, pNewIconData, dwNewIconSize); // 写入替换后的图标资源 SetFilePointer(hFile, dwIconOffset + sizeof(IMAGE_RESOURCE_DATA_ENTRY), NULL, FILE_BEGIN); if (!WriteFile(hFile, pIconData, dataEntry.Size, &dwBytesRead, NULL) || dwBytesRead != dataEntry.Size) { delete[] pIconData; delete[] pNewIconData; CloseHandle(hFile); DestroyIcon((HICON)hNewIcon); return FALSE; } delete[] pIconData; delete[] pNewIconData; CloseHandle(hFile); DestroyIcon((HICON)hNewIcon); return TRUE; } } } } CloseHandle(hFile); return FALSE; } ``` 调用示例: ```c++ ReplaceExeIcon(TEXT("C:\\MyApp.exe"), 101, TEXT("C:\\NewIcon.ico")); ``` 其中,`lpExePath` 参数为需要替换图标的exe文件路径,`dwIconResourceId` 参数为需要替换的图标资源的ID,`lpNewIconPath` 参数为新的图标文件路径。如果函数执行成功,则返回 `TRUE`,如果失败,则返回 `FALSE`。

相关推荐

最新推荐

recommend-type

HP-Socket编译-Linux

HP-Socket编译-Linux
recommend-type

JavaScript_生活在Discord上的开源社区列表.zip

JavaScript
recommend-type

JavaScript_MultiOn API.zip

JavaScript
recommend-type

JavaScript_简单和完整的React DOM测试工具,鼓励良好的测试实践.zip

JavaScript
recommend-type

JavaScript_成为一个Nodejs开发者.zip

JavaScript
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

可见光定位LED及其供电硬件具体型号,广角镜头和探测器,实验设计具体流程步骤,

1. 可见光定位LED型号:一般可使用5mm或3mm的普通白色LED,也可以选择专门用于定位的LED,例如OSRAM公司的SFH 4715AS或Vishay公司的VLMU3500-385-120。 2. 供电硬件型号:可以使用常见的直流电源供电,也可以选择专门的LED驱动器,例如Meanwell公司的ELG-75-C或ELG-150-C系列。 3. 广角镜头和探测器型号:一般可采用广角透镜和CMOS摄像头或光电二极管探测器,例如Omron公司的B5W-LA或Murata公司的IRS-B210ST01。 4. 实验设计流程步骤: 1)确定实验目的和研究对象,例如车辆或机器人的定位和导航。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。