MFC picture控件中显示图片

2024-03-23 16:18
文章标签 显示 图片 mfc 控件 picture

本文主要是介绍MFC picture控件中显示图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PictureBox 控件的主要作用是为用户显示图片。实际显示图片由 Picture 属性决定。Picture属性包括被显示的图片的文件名(及可选的路径名)。
  注意 窗体对象也具有 Picture 属性,通过设置该属性可直接在窗体背景上显示图片。
  要在运行时显示或替换图片,可利用函数 LoadPicture 来设置 Picture 属性。提供图片文件名和可选路径名,由 LoadPicture 函数处理加载和显示图片的细节。
  picMain.Picture = LoadPicture("VANGOGH.BMP")
  PictureBox 控件具有 AutoSize 属性,当该属性设置为 True 时,PictureBox 能自动调整大小与显示的图片匹配。如果要用 AutoSize 属性设置为 True  PictureBox ,设计窗体时就需要特别小心。图片将不考虑窗体上的其它控件而调整大小,这可能导致意想不到的后果,如覆盖其它控件。设计时应通过加载每一幅图片来检查是否有这种现象发生。

 

vc picture控件的分类进行拉总结,

(非动态显示图片(即图片先通过资源管理器载入,有一个固定ID)

(
动态载入图片(即只需要在程序中指定图片的路径即可载入
)



为方便说明,我们已经建好一个基于对话框的工程,名为
Ttest.

对话框类为
CTestDlg

(
)     vc picture控件非动态载入图片
.



方法1.先从最简单的开始,picture 控件来实现
.

步骤
:

先在资源里Import一张图片,ID
IDB_BITMAP2

然后在对话框上添加一个picture控件,右键点击打开属性
,

type下拉框选择BITMAP,紧跟着下面就出现一个Image下拉框
,

拉开就会看到所有已经载入好的图片
,

选择你要的图片.运行程序即可看到
.



方法2vc picture控件.通过背景图


同样如上,先载入一张图片,IDIDB_BITMAP2

TestDlg.h


CBrush m_brBk;//
public中定义 

TestDlg.cpp


在初始化函数OnInitDialog()中加入:

BOOL CTestDlg::OnInitDialog()

{

                CDialog::OnInitDialog();

CBitmap bmp;

bmp.LoadBitmap(IDB_BITMAP2);

m_brBk.CreatePatternBrush(&bmp);

bmp.DeleteObject();

return TRUE;   // return TRUE   unless you set the focus to a control

}



在打开类向导,找到WM_CTLCOLOR消息,重载得对应函数OnCtlColor(),添加如下
:

HBRUSH   CTestDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) 

{

                HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);

                if (pWnd == this)

{

     return m_brBk;

}

        return hbr;

}

 

From:http://blog.china.com/u/100306/372913/201003/5956650.html

 

 

基于MFC控件STATIC显示图片数据

1.       在 OnInitDialog 中加入

       GetDlgItem(IDC_MY_PIC)->ModifyStyle ( SS_TYPEMASK, SS_OWNERDRAW );     

2.       在butto 按钮中加入以下,可以显示多中类型的图片资源

void CDlgpicDlg::OnTest()

{

       // TODO: Add your command handler code here

       CFileDialog fileDlg(TRUE,NULL,NULL,

              OFN_ALLOWMULTISELECT,

              _T("Picture Files (*.bmp *.ico *.jpg)|*bmp;*.ico;*jpg|All Files (*.*)|*.*||"),

              AfxGetMainWnd());

 

       CString pathName;

       if(fileDlg.DoModal ()==IDOK)

       {

              POSITION mPos=fileDlg.GetStartPosition();

              while(mPos!=NULL)

              {

                     pathName=fileDlg.GetNextPathName(mPos);

                     if(m_pict.LoadPicture(pathName.GetBuffer(pathName.GetLength())))

                     {

                            // 防止有透明图片,消除已有的图片信息

                            CPaintDC dc(this); // device context for painting

                            CRect rc;

                            GetDlgItem(IDC_MY_PIC)->GetWindowRect(&rc);

                            dc.FillSolidRect(rc, RGB(0, 0, 0));

                            Invalidate();

                     }

              }

       }    

}

3.给父窗口增加ON_WM_DRAWITEM消息映射函数 在OnDrawItem(int nIDCtl, LPDRAWITEMSTRUCT lpDrawItemStruct)消息映射函数里面绘制控件

void CDlgpicDlg::OnDrawItem(int nIDCtl, LPDRAWITEMSTRUCT lpDrawItemStruct)

{

       // TODO: Add your message handler code here and/or call default

       if(nIDCtl == IDC_MY_PIC)

       {

              if ( m_pict.m_pic)

              {

             

                     RECT rect;

                     TRACE("--hell-- test---");

                     HWND hwnd = ::GetDlgItem(this->GetSafeHwnd(), IDC_MY_PIC);

                    

                     HDC hDC = ::GetDC(::GetDlgItem(this->GetSafeHwnd(),IDC_MY_PIC));      

                     //Get the DC for the CPicture Box

                     ::GetClientRect(::GetDlgItem(this->GetSafeHwnd(), IDC_MY_PIC), &rect);  

                     //Get dimensions of it

                     m_pict.DrawPicture(hDC, 0, 0, rect.right - rect.left ,rect.bottom - rect.top );

                     ::ReleaseDC(::GetDlgItem(this->GetSafeHwnd(),IDC_MY_PIC), hDC);   

                    

              }

       }    

       CDialog::OnDrawItem(nIDCtl, lpDrawItemStruct);

}

总结: 如果在static中需要显示图片,在ONPAINT 中绘画 没有效果,需要这么画:

1)给static控件增加SS_OWNERDRAW属性      GetDlgItem(IDC_MY_PIC)->ModifyStyle ( SS_TYPEMASK, SS_OWNERDRAW );   

2)给父窗口增加ON_WM_DRAWITEM消息映射函数

3)在OnDrawItem(int nIDCtl, LPDRAWITEMSTRUCT lpDrawItemStruct)消息映射函数里面绘制控件

例如:下面给对话框里的IDC_STATIC_DRAW控件画个蓝色的背景

void CMyDlg::OnDrawItem(int nIDCtl, LPDRAWITEMSTRUCT lpDrawItemStruct)

{

if(nIDCtl == IDC_STATIC_DRAW)

{

CDC *pDC = CDC::FromHandle(lpDrawItemStruct->hDC);

pDC->FillSolidRect(10, 10, lpDrawItemStruct->rcItem.right - 20, lpDrawItemStruct->rcItem.bottom - 20, RGB(0, 0, 255));

return;

}

CDialog::OnDrawItem(nIDCtl, lpDrawItemStruct);

}

另外,还可以这么画

从CStatic继承一个新类,然后增加WM_PAINT消息处理,在OnPaint里面画

例如:

class CMyStatic : public CStatic

{

...

afx_msg void OnPaint();

};

void CMyStatic::OnPaint()

{

CPaintDC dc(this); // device context for painting

CRect rc;

GetClientRect(rc);

dc.FillSolidRect(rc, RGB(0, 0, 255));

}    

 

 

转载自:http://www.cnblogs.com/lemon0823/archive/2013/03/08/2949386.html

这篇关于MFC picture控件中显示图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

Spring MVC 图片上传

引入需要的包 <dependency><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId><version>1.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-

Prompt - 将图片的表格转换成Markdown

Prompt - 将图片的表格转换成Markdown 0. 引言1. 提示词2. 原始版本 0. 引言 最近尝试将图片中的表格转换成Markdown格式,需要不断条件和优化提示词。记录一下调整好的提示词,以后在继续优化迭代。 1. 提示词 英文版本: You are an AI assistant tasked with extracting the content of

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t

研究人员在RSA大会上演示利用恶意JPEG图片入侵企业内网

安全研究人员Marcus Murray在正在旧金山举行的RSA大会上公布了一种利用恶意JPEG图片入侵企业网络内部Windows服务器的新方法。  攻击流程及漏洞分析 最近,安全专家兼渗透测试员Marcus Murray发现了一种利用恶意JPEG图片来攻击Windows服务器的新方法,利用该方法还可以在目标网络中进行特权提升。几天前,在旧金山举行的RSA大会上,该Marcus现场展示了攻击流程,