📄 02824227view.cpp
字号:
// 02824227View.cpp : implementation of the CMy02824227View class
//
#include "stdafx.h"
#include "02824227.h"
#include "02824227Doc.h"
#include "02824227View.h"
#include "dibapi.h"
#include "Dlg_02824227.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CMy02824227View
IMPLEMENT_DYNCREATE(CMy02824227View, CView)
BEGIN_MESSAGE_MAP(CMy02824227View, CView)
//{{AFX_MSG_MAP(CMy02824227View)
ON_COMMAND(ID_VIEW_Intensity, OnVIEWIntensity)
ON_COMMAND(ID_MENUITEM32772, OnMenuitem32772)
//}}AFX_MSG_MAP
// Standard printing commands
ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CMy02824227View construction/destruction
CMy02824227View::CMy02824227View()
{
// TODO: add construction code here
}
CMy02824227View::~CMy02824227View()
{
}
BOOL CMy02824227View::PreCreateWindow(CREATESTRUCT& cs)
{
// TODO: Modify the Window class or styles here by modifying
// the CREATESTRUCT cs
return CView::PreCreateWindow(cs);
}
/////////////////////////////////////////////////////////////////////////////
// CMy02824227View drawing
void CMy02824227View::OnDraw(CDC* pDC)
{
// 显示等待光标
BeginWaitCursor();
// 获取文档
CMy02824227Doc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
//锁定DIB
lpDIB=(LPSTR)::GlobalLock((HGLOBAL)pDoc->GetHDIB());
//找到DIB图像像素的起始位置
lpDIBBits=::FindDIBBits(lpDIB);
height=::DIBHeight(lpDIB);
width=::DIBWidth(lpDIB);
// 指向BITMAPINFO结构的指针(Win3.0)
LPBITMAPINFO lpbmi;
// 获取指向BITMAPINFO结构的指针(Win3.0)
lpbmi = (LPBITMAPINFO)lpDIB;
// 计算图像每行的字节数
lLineBytes = WIDTHBYTES(width * 8);
LONG i,j;
LONG R,G,B;
//打点显示
for (i = 0; i < height; i ++)
{
for (j = 0; j < width; j ++)
{
// 指向图像指针
lpSrc = (unsigned char *)lpDIBBits + lLineBytes * i + j;
//查询颜色查找表LUT
R=lpbmi->bmiColors[*lpSrc].rgbRed;
G=lpbmi->bmiColors[*lpSrc].rgbGreen;
B=lpbmi->bmiColors[*lpSrc].rgbBlue;
pDC->SetPixel(j,height-i,RGB(R,G,B));
}
}
}
/////////////////////////////////////////////////////////////////////////////
// CMy02824227View printing
BOOL CMy02824227View::OnPreparePrinting(CPrintInfo* pInfo)
{
// default preparation
return DoPreparePrinting(pInfo);
}
void CMy02824227View::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
// TODO: add extra initialization before printing
}
void CMy02824227View::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
// TODO: add cleanup after printing
}
/////////////////////////////////////////////////////////////////////////////
// CMy02824227View diagnostics
#ifdef _DEBUG
void CMy02824227View::AssertValid() const
{
CView::AssertValid();
}
void CMy02824227View::Dump(CDumpContext& dc) const
{
CView::Dump(dc);
}
CMy02824227Doc* CMy02824227View::GetDocument() // non-debug version is inline
{
ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CMy02824227Doc)));
return (CMy02824227Doc*)m_pDocument;
}
#endif //_DEBUG
/////////////////////////////////////////////////////////////////////////////
// CMy02824227View message handlers
void CMy02824227View::OnVIEWIntensity()
{
// TODO: Add your command handler code here
// 查看当前图像灰度直方图
// 获取文档
CMy02824227Doc* pDoc = GetDocument();
// 指向DIB的指针
LPSTR lpDIB;
// 指向DIB象素指针
LPSTR lpDIBBits;
// 锁定DIB
lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->GetHDIB());
// 找到DIB图像象素起始位置
lpDIBBits = ::FindDIBBits(lpDIB);
// 判断是否是8-bpp位图(这里为了方便,只处理8-bpp位图,其它的可以类推)
if (::DIBNumColors(lpDIB) != 256)
{
// 提示用户
MessageBox("目前只支持查看256色位图灰度直方图!", "系统提示" , MB_ICONINFORMATION | MB_OK);
// 解除锁定
::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
// 返回
return;
}
// 更改光标形状
BeginWaitCursor();
// 创建对话框
Dlg_02824227 dlgPara;
// 初始化变量值
dlgPara.m_lpDIBBits = lpDIBBits;
dlgPara.m_lWidth = ::DIBWidth(lpDIB);
dlgPara.m_lHeight = ::DIBHeight(lpDIB);
dlgPara.m_iLowGray = 0;
dlgPara.m_iUpGray = 255;
// 显示对话框,提示用户设定平移量
if (dlgPara.DoModal() != IDOK)
{
// 返回
return;
}
// 解除锁定
::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
// 恢复光标
//EndWaitCursor();
}
void CMy02824227View::OnMenuitem32772()
{
// TODO: Add your command handler code here
CClientDC pDC(this);
HDC hDC=pDC.GetSafeHdc();//获取当前设备上下文的句柄
SetStretchBltMode(hDC,COLORONCOLOR); //设置伸展模式为覆盖操作,即把原来的图像直接覆盖显示
HANDLE data1handle;//定义句柄data1handle
LPBITMAPINFOHEADER lpBi; //定义文件头信息lpBi
CMy02824227Doc *pDoc=GetDocument();//得到文档类的指针
HDIB hdib;//定义位图文件句柄
unsigned char *hData;//位图文件进行滤波平滑处理前的数据信息
unsigned char *data;//位图文件进行滤波平滑处理后的数据信息
hdib=pDoc->GetHDIB();//得到当前打开的位图文件的句柄
BeginWaitCursor();//显示等待光标
lpBi=(LPBITMAPINFOHEADER)GlobalLock((HGLOBAL)hdib);//锁定位图文件,得到其文件头信息
hData=(unsigned char*)FindDIBBits((LPSTR)lpBi);//根据图像的结构得到位图的灰度值数据
pDoc->SetModifiedFlag(TRUE);//设置文档修改标志为“真”、为后续的修改存盘作准备;
//声明一个缓冲区用来暂存处理后的图像数据;
data1handle=GlobalAlloc(GMEM_SHARE,WIDTHBYTES(lpBi->biWidth*8)*lpBi->biHeight);
//得到该缓冲区的指针;
data=(unsigned char*)GlobalLock((HGLOBAL)data1handle);
AfxGetApp()->BeginWaitCursor();
int i,j,s,t,ms=1;
int sum=0,sumw=0;
int mask[3][3]={{1,1,1},{1,1,1},{1,1,1}};//定义的3x3加权平滑模板
for(i=0; i<height; i++)//从图像坐上角开始对图像的各个像素进行滤波平滑处理
for(j=0; j<width; j++)
{
sumw=0;//当前像素以及周围像素中被模板包围住的像素个数,之多为9个,至少为3个
sum=0;//这些像素的灰度值的总和
for(s=(-ms); s<=ms; s++)
for(t=(-ms); t<=ms; t++)
if(((i+s)>=0)&&((j+t)>=0)&&((i+s)<height)&&((j+t)<width))
{
sumw += mask[1+s][1+t];//像素个数
sum+=*(hData+(i+s)*WIDTHBYTES(lpBi->biWidth*8)+(j+t))*mask[1+s][1+t];
//求取灰度值
}
if(sumw==0)//如果当前模板包围圈内没有任何像素的话,将分母置1
sumw=1;
sum/=sumw;//采取领域平均办法求解
if(sum>255)
sum=255;
if(sum<0)
sum=0;
*(data+i*WIDTHBYTES(lpBi->biWidth*8)+j)=sum;//将求取的值保存到当前像素位置
}
for(i=0;i<height;i++)
for(j=0;j<width;j++)
//重新写回原始图像的数据缓冲区
*(hData+i*WIDTHBYTES(lpBi->biWidth*8)+j)=*(data+i*WIDTHBYTES(lpBi->biWidth*8)+j);
StretchDIBits(hDC,0,0,lpBi->biWidth,lpBi->biHeight,0,0,
lpBi->biWidth,lpBi->biHeight,hData,(LPBITMAPINFO)lpBi,
DIB_RGB_COLORS,SRCCOPY);//显示图像
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -