如何在用户区显示一张位图

博客介绍了显示位图的三种基本形式,包括位图资源的显示、创建位图并绘图后显示、显示磁盘上的外部BMP文件,且每种形式都给出了具体的代码实现,涉及建立内存设备场境、选入位图、绘制图形等操作。
显示一张位图,基本的有以下三种形式:
一、位图资源的显示(设资源ID为IDB——BITMAP1程序如下)
{
    CBitmap bitmap;
    CBitmap* pOldBitmap;
    CDC MemDC;
    MemDC.CreateCompatibleDC(&dc); ///建立与显示设备兼容的内存设备场境
    bitmap.LoadBitmap(IDB_BITMAP1); ///取出位图资源
    pOldBitmap=MemDC.SelectObject(&bitmap); ///将位图选入内存场境
    dc.BitBlt(50,50,48,48,&MemDC,0,0,SRCCOPY); ///显示它
    MemDC.SelectObject(pOldBitmap);
}
二、创建位图,然后在里面画上图形,再显示它
{
    CBitmap bitmap;
    CBitmap* pOldBitmap;
    CDC MemDC;
    int i;
    CPen pen;
    CPen* oldpen;
    MemDC.CreateCompatibleDC(&dc); ///建立与显示设备兼容的内存设备场境
    bitmap.CreateCompatibleBitmap(&dc,100,100);///建立与显示设备兼容的位图
    pOldBitmap=MemDC.SelectObject(&bitmap); ///将位图选入内存场境
    for(i=0;i<100;i++)
    { ///画100根线
       pen.CreatePen(PS_SOLID,1, RGB(0,0,i*2+55));    
       oldpen=MemDC.SelectObject(&pen);
       MemDC.MoveTo(0,i);
       MemDC.LineTo(100,i);
       MemDC.SelectObject(oldpen);
       pen.DeleteObject();
    }
    dc.BitBlt(50,50,100,100,&MemDC,0,0,SRCCOPY); ///显示它
    MemDC.SelectObject(pOldBitmap);
}
三、显示磁盘上的外部BMP文件
{
   HBITMAP bitmap;
   /////读取位图文件SAMPLE.BMP
   bitmap=(HBITMAP)LoadImage(AfxGetInstanceHandle(),"SAMPLE.BMP",IMAGE_BITMAP,0,0,LR_LOADFROMFILE|LR_CREATEDIBSECTION);
   ASSERT(bitmap);
   HBITMAP OldBitmap;
   CDC MemDC;CRect rect;
   MemDC.CreateCompatibleDC(&dc);
   GetClientRect(rect);
   OldBitmap=(HBITMAP)MemDC.SelectObject(bitmap);
   ///显示它
   dc.BitBlt(20,20,rect.Width()-20,rect.Height()-20,&MemDC,0,0,SRCCOPY);
   MemDC.SelectObject(OldBitmap);
}
MATLAB主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性内容概要:本文主要介绍了一种在MATLAB环境下实现的主动噪声和振动控制算法,该算法针对较大的次级路径变化具有较强的鲁棒性。文中详细阐述了算法的设计原理与实现方法,重点解决了传统控制系统中因次级路径动态变化导致性能下降的问题。通过引入自适应机制和鲁棒控制策略,提升了系统在复杂环境下的稳定性和控制精度,适用于需要高精度噪声与振动抑制的实际工程场景。此外,文档还列举了多个MATLAB仿真实例及相关科研技术服务内容,涵盖信号处理、智能优化、机器学习等多个交叉领域。; 适合人群:具备一定MATLAB编程基础和控制系统理论知识的科研人员及工程技术人员,尤其适合从事噪声与振动控制、信号处理、自动化等相关领域的研究生和工程师。; 使用场景及目标:①应用于汽车、航空航天、精密仪器等对噪声和振动敏感的工业领域;②用于提升现有主动控制系统对参数变化的适应能力;③为相关科研项目提供算法验证与仿真平台支持; 阅读建议:建议读者结合提供的MATLAB代码进行仿真实验,深入理解算法在不同次级路径条件下的响应特性,并可通过调整控制参数进一步探究其鲁棒性边界。同时可参考文档中列出的相关技术案例拓展应用场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值