创建8位DIB并显示

2024-01-29 17:08
文章标签 显示 创建 dib

本文主要是介绍创建8位DIB并显示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   做的一个项目由于系统是8位的,对于24位的DIB位图使用BitBlt函数的时候非常慢,在debug下测试对于2500*2500的图像,BitBlt函数用了大概4000-5000ms,非常的受不了,这里主要是由于系统是8位的,你创建的是24位的DIB,这时候用BitBlt函数的时候系统会做很多转换工作,所以速度就非常慢,解决办法就是直接创建8位的DIB来显示,和显示24位DIB最大的不同就是要把调色板信息加到位图文件头中:

 

LPBYTE lpBitmapInfo = NULL;
BITMAPINFOHEADER *lpBitmapHeader;
RGBQUAD *lpRgb;
int i;

lpBitmapInfo = (LPBYTE)new char[sizeof(BITMAPINFOHEADER) + 256 * sizeof(RGBQUAD) ];
if (lpBitmapInfo == NULL)  
return;
lpBitmapHeader = (BITMAPINFOHEADER *)lpBitmapInfo;
lpBitmapHeader->biSize = sizeof (BITMAPINFOHEADER) ;
lpBitmapHeader->biWidth = wnd_w ;
lpBitmapHeader->biHeight = -wnd_h ;
lpBitmapHeader->biPlanes = 1 ;
lpBitmapHeader->biBitCount = 8 ;
lpBitmapHeader->biCompression = BI_RGB ;

lpBitmapHeader->biSizeImage = wnd_w * wnd_h;
lpBitmapHeader->biXPelsPerMeter = 0 ;
lpBitmapHeader->biYPelsPerMeter = 0 ;
lpBitmapHeader->biClrUsed = 0 ;
lpBitmapHeader->biClrImportant = 0 ;

关于调色板的地方不用自己再去设置系统调色板,要直接再创建位图的时候加上去
lpRgb = (RGBQUAD *)(lpBitmapInfo + sizeof(BITMAPINFOHEADER));
for (i = 0; i < 256; i++) {
lpRgb->rgbBlue = i;
lpRgb->rgbGreen = i;
lpRgb->rgbRed = i;
lpRgb->rgbReserved = 0;
lpRgb++;
}

hbitmap=CreateDIBSection(dc.GetSafeHdc(),

(CONST BITMAPINFO *)lpBitmapInfo,
DIB_RGB_COLORS,  
//DIB_PAL_COLORS,
(void **)&rev_buff,  
  NULL,
0);

 

memcpy(rev_buff, g_pTempBuff, wnd_w*wnd_h);//g_pTempBuff中存放的是8位灰度值。

 dc.BitBlt(0, 0, wnd_w, wnd_h, &dcCompatible, 0, 0, SRCCOPY);

 

 

OK,这样BitBlt的时间在DEBUG下不超过500ms了。

转自:http://blog.csdn.net/bigapple88/article/details/5746956

这篇关于创建8位DIB并显示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/657601

相关文章

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

MySQL 临时表创建与使用详细说明

《MySQL临时表创建与使用详细说明》MySQL临时表是存储在内存或磁盘的临时数据表,会话结束时自动销毁,适合存储中间计算结果或临时数据集,其名称以#开头(如#TempTable),本文给大家介绍M... 目录mysql 临时表详细说明1.定义2.核心特性3.创建与使用4.典型应用场景5.生命周期管理6.注

MySQL的触发器全解析(创建、查看触发器)

《MySQL的触发器全解析(创建、查看触发器)》MySQL触发器是与表关联的存储程序,当INSERT/UPDATE/DELETE事件发生时自动执行,用于维护数据一致性、日志记录和校验,优点包括自动执行... 目录触发器的概念:创建触www.chinasem.cn发器:查看触发器:查看当前数据库的所有触发器的定

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

python如何创建等差数列

《python如何创建等差数列》:本文主要介绍python如何创建等差数列的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python创建等差数列例题运行代码回车输出结果总结python创建等差数列import numpy as np x=int(in