亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dynsplitview2.cpp

?? 圖像處理算法相關VC程序 VC++圖像處理程序設計配套光盤
?? CPP
字號:
// DynSplitView2.cpp : implementation file
//

#include "stdafx.h"
#include "DSplit.h"
#include "DynSplitView2.h"
#include "DlgPingYi.h"
#include "DlgSuoFang.h"
#include "math.h"
#include "DlgXuanZhuan.h"
#include "JiHeBianHuanDib.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CDynSplitView2

IMPLEMENT_DYNCREATE(CDynSplitView2, CView)

CDynSplitView2::CDynSplitView2()
{
	state2=0;
	state3=1;
}

/*初始化圖像數據*/
void CDynSplitView2::clearmem()
{
	CDSplitDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc ->statedoc=0;
    state2=1;
	CDibNew1=&pDoc->CDibNew;
    CDib1=&pDoc->CDib;
    long int  size;
	if(CDibNew1->m_pBitmapInfoHeader->biBitCount<9)	
		size=CDib1->GetHeight()*CDib1->GetWidth();
	else
		size=CDib1->GetHeight()*CDib1->GetWidth()*3;

    memcpy(CDibNew1->m_pData,CDib1->m_pData,size);
	CDibNew1->SetHeight(CDib1->GetHeight());
    CDibNew1->SetWidth(CDib1->GetWidth());
}

CPalette * CDynSplitView2::CreateBitmapPalette(JiHeBianHuanDib * pBitmap)
{
	struct
	{
		WORD Version;
		WORD NumberOfEntries;
		PALETTEENTRY aEntries[256];
	} palette = { 0x300, 256 };
	
	LPRGBQUAD pRGBTable = pBitmap->GetRGB();
	UINT numberOfColors = pBitmap->GetNumberOfColors();
	
	for(UINT x=0; x<numberOfColors; ++x)
	{
		palette.aEntries[x].peRed =
			pRGBTable[x].rgbRed;
		palette.aEntries[x].peGreen =
			pRGBTable[x].rgbGreen;
		palette.aEntries[x].peBlue =
			pRGBTable[x].rgbBlue;
		palette.aEntries[x].peFlags = 0;
	}
	
	hPalette.CreatePalette((LPLOGPALETTE)&palette);
	return &hPalette;
}

CDynSplitView2::~CDynSplitView2()
{
}

CDSplitDoc* CDynSplitView2::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CDSplitDoc)));
	return (CDSplitDoc*)m_pDocument;
}


BEGIN_MESSAGE_MAP(CDynSplitView2, CView)
	//{{AFX_MSG_MAP(CDynSplitView2)
	ON_WM_ERASEBKGND()
	ON_COMMAND(ID_FILESAVE, OnFilesave)
	ON_COMMAND(ID_Tuxiangpingyi, OnTuxiangpingyi)
	ON_COMMAND(ID_Shuipingjingxiang, OnShuipingjingxiang)
	ON_COMMAND(ID_Chuizhijingxiang, OnChuizhijingxiang)
	ON_COMMAND(ID_Zhuanzhi, OnZhuanzhi)
	ON_COMMAND(ID_Xuanzhuan, OnXuanzhuan)
	ON_COMMAND(ID_Fangda, OnFangda)
	ON_COMMAND(ID_SuoXiao, OnSuoXiao)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDynSplitView2 drawing

void CDynSplitView2::OnDraw(CDC* pDC)
{	
	CDSplitDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	
	if(!pDoc ->statedoc&&state2==1)
	{
        BYTE* pBitmapData = CDibNew1->GetData();
        LPBITMAPINFO pBitmapInfo = CDibNew1->GetInfo();
        int bitmapHeight = CDibNew1->GetHeight();
        int bitmapWidth = CDibNew1->GetWidth();
		int scaledWidth = (int)(bitmapWidth * 1);
		int scaledHeight = (int)(bitmapHeight * 1);
		if (CDibNew1->GetRGB()) // Has a color table
		{
			CPalette * hPalette1=CreateBitmapPalette(CDibNew1);
            CPalette * hOldPalette =
                pDC->SelectPalette(hPalette1, true);
            pDC->RealizePalette();
			::StretchDIBits(pDC->GetSafeHdc(),0,0, bitmapWidth, bitmapHeight,
				0, 0, bitmapWidth , bitmapHeight ,
				pBitmapData, pBitmapInfo,
				DIB_RGB_COLORS, SRCCOPY);
            pDC->SelectPalette(hOldPalette, true);
            hPalette.DeleteObject();
			CDibNew1->SetWidth(bitmapWidth);
			CDibNew1->SetHeight(bitmapHeight);
		}
		else
		{
			
            ::StretchDIBits(pDC->GetSafeHdc(),
                0, 0, scaledWidth, scaledHeight,
                0, 0, bitmapWidth, bitmapHeight,
				pBitmapData, pBitmapInfo,
				DIB_RGB_COLORS, SRCCOPY);
			CDibNew1->SetWidth(bitmapWidth);
			CDibNew1->SetHeight(bitmapHeight);
		}
	}
	
    
}


/////////////////////////////////////////////////////////////////////////////
// CDynSplitView2 diagnostics

#ifdef _DEBUG
void CDynSplitView2::AssertValid() const
{
	CView::AssertValid();
}

void CDynSplitView2::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CDynSplitView2 message handlers

BOOL CDynSplitView2::OnEraseBkgnd(CDC* pDC) 
{
	CRect rect;
	GetClientRect(&rect);
	pDC->FillSolidRect(&rect,::GetSysColor(COLOR_WINDOW));
	return TRUE;
}
 
void CDynSplitView2::OnFilesave() 
{
	CFileDialog dlg(FALSE,_T("BMP"),_T("*.BMP"),OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,_T("位圖文件(*.BMP)|*.BMP|"));	
    if(IDOK==dlg.DoModal())
		CString  filename;
    filename.Format ("%s",dlg.GetPathName() );    
    CDibNew1->SaveFile(filename);
	state2=1;
	Invalidate();
}

/*平移消息映射*/
void CDynSplitView2::OnTuxiangpingyi() 
{
	int x,y;
	if(state3==0)
		CDibNew1->clearmem2(); 
	MessageBox("正數表示右移量或下移量,負數表示左移量或上移量");
	//初始化圖像數據
	clearmem();
	// 創建對話框
	CDlgPingYi  dlg;
	dlg.m_Xmove=10;
	dlg.m_Ymove=10;

	// 顯示對話框,提示用戶設定窗口上下限
	if (dlg.DoModal() != IDOK)
		return;// 返回

	x=dlg.m_Xmove;
	y=dlg.m_Ymove;
	
	// 刪除對話框
	delete dlg;	
	CDibNew1->PingYi(x,y); 
	Invalidate();           //調用刷新函數
	state3=1;
}

/*水平鏡像消息映射*/
void CDynSplitView2::OnShuipingjingxiang() 
{
	clearmem();
	CDibNew1->JingXiang(TRUE);             //調用水平鏡像處理函數
    Invalidate();           //調用刷新函數
}

/*垂直鏡像消息映射*/
void CDynSplitView2::OnChuizhijingxiang() 
{
	clearmem();
	CDibNew1->JingXiang(FALSE);             //調用垂直鏡像處理函數
    Invalidate();           //調用刷新函數
}

/*轉置消息映射*/
void CDynSplitView2::OnZhuanzhi() 
{
	clearmem();	
	CDibNew1->Zhuanzhi();             //調用轉置處理函數
    Invalidate(); //調用刷新函數
    state3=0;
}
 



void CDynSplitView2::OnXuanzhuan() 
{
	MessageBox("角度應為90度的整數倍,且圖像的高和寬需相同");
	clearmem();
	
	int iRotateAngle;			// 旋轉角度
	CDlgXuanZhuan dlg;			// 創建對話框
	dlg.m_iRotateAngle = 90;	// 初始化變量值
	
	// 顯示對話框,提示用戶設定旋轉角度
	if (dlg.DoModal() != IDOK)
	{
		return;// 返回
	}
	
	// 獲取用戶設定的旋轉量
	iRotateAngle = dlg.m_iRotateAngle;
	CDibNew1->Xuanzhuan(iRotateAngle);
	this->Invalidate();
}

//圖像放大消息映射
void CDynSplitView2::OnFangda() 
{
	if(state3==0)
		CDibNew1->clearmem2(); 
	clearmem();	
	float xzoom,yzoom;
	CDlgSuoFang  dlg;		// 定義對話框
	dlg.m_XZoom=2.0;
	dlg.m_YZoom=2.0;

	// 顯示對話框,提示用戶設定窗口上下限
	if (dlg.DoModal() != IDOK)
	{
		return;				// 返回
	}
    xzoom=dlg.m_XZoom;
    yzoom=dlg.m_YZoom;
	delete dlg;				// 刪除對話框

	// 源圖像的寬度和高度
	LONG	wide;
	LONG	height;
	
	// 縮放后圖像的寬度和高度
	LONG	newwide;
	LONG	newheight;
	LONG	newLineBytes;
	LPBYTE	temp;
	
	// 獲取圖像的寬度和高度
	wide = CDibNew1->GetWidth();
	height = CDibNew1->GetHeight();

	if(CDibNew1->m_pBitmapInfoHeader->biBitCount<9)
	{
		// 計算縮放后的圖像寬度和高度
		newwide = (LONG) (wide * xzoom +0.5);
		newheight = (LONG) (height * yzoom+0.5);
		newLineBytes=(newwide*8+31)/32*4;

		// 分配內存,以保存新DIB
		temp = new BYTE[ newLineBytes * newheight ];
		memset(temp,0,newLineBytes * newheight);
		CDibNew1->m_pData=CDibNew1->FangDa(temp,xzoom,yzoom,wide,height,newLineBytes,newheight);  
		CDibNew1->SetWidth(newwide);
		CDibNew1->SetHeight(newheight);
		Invalidate();           //調用刷新函數
	}
	else
	{
		// 計算縮放后的圖像寬度和高度
		newwide = (LONG) (wide * xzoom*3);
		newheight = (LONG) (height * yzoom);
		
		// 分配內存,以保存新DIB
		temp = new BYTE[ newwide * newheight];
		memset(temp,0,newwide * newheight);
		CDibNew1->m_pData=CDibNew1->FangDa(temp,xzoom,yzoom,wide,height,newwide,newheight); 
		CDibNew1->SetWidth(newwide/3);
		CDibNew1->SetHeight(newheight);
		Invalidate();           //調用刷新函數
	}
}

//圖像縮小消息映射
void CDynSplitView2::OnSuoXiao() 
{
	if(state3==0)
		CDibNew1->clearmem2(); 

	float x,y;					//縮小倍數
	clearmem();	
	CDlgSuoFang  dlg;			//創建對話框
	dlg.m_XZoom=0.5;
	dlg.m_YZoom=0.5;

	// 顯示對話框,提示用戶設定窗口上下限
	if (dlg.DoModal() != IDOK)
	{
		return;					//返回
	}
	x=dlg.m_XZoom;
	y=dlg.m_YZoom;

	delete dlg;					//刪除對話框	 
	CDibNew1->SuoXiao( x, y );	//調用縮小處理函數
    Invalidate();				//調用刷新函數
	state3=1;
}

void CDynSplitView2::clearmem(float xzoom, float yzoom)
{
	CDSplitDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->statedoc=0;
    state2=1;
	CDibNew1=&pDoc->CDibNew;
    CDib1=&pDoc->CDib;
	long int  size=CDib1->GetHeight()*CDib1->GetDibWidthBytes()*xzoom;
	memcpy(CDibNew1->m_pData,CDib1->m_pData,size);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲综合色噜噜狠狠| 欧美在线不卡视频| 亚洲精品综合在线| 日韩精品在线网站| 日本精品一区二区三区高清| 丝袜美腿亚洲综合| 精品视频一区三区九区| 不卡一区二区中文字幕| 蜜桃一区二区三区四区| 亚洲精品写真福利| 中文字幕免费不卡| 精品动漫一区二区三区在线观看| 欧美在线视频日韩| 国产91精品精华液一区二区三区| 日本免费新一区视频| 亚洲精选免费视频| 中文字幕亚洲区| 久久久久久久久久久久久久久99| 欧美高清一级片在线| 91九色最新地址| 91玉足脚交白嫩脚丫在线播放| 韩国女主播一区二区三区| 午夜私人影院久久久久| 亚洲老司机在线| 中文字幕日本乱码精品影院| 中文字幕精品综合| 国产清纯在线一区二区www| 精品毛片乱码1区2区3区| 91精品国产一区二区三区蜜臀 | 久久久国产综合精品女国产盗摄| 欧美日本一区二区三区四区| 色婷婷亚洲综合| 91蜜桃免费观看视频| 不卡视频免费播放| 99久久精品免费看| 成人丝袜18视频在线观看| 久久99精品久久久| 精品亚洲国产成人av制服丝袜 | 99热国产精品| 9i在线看片成人免费| 成人av网在线| 北岛玲一区二区三区四区 | 日韩欧美卡一卡二| 日韩视频免费观看高清完整版 | 成人午夜激情视频| 成人午夜av在线| 成人妖精视频yjsp地址| proumb性欧美在线观看| 99精品久久免费看蜜臀剧情介绍 | 欧美高清一级片在线| 678五月天丁香亚洲综合网| 精品视频在线免费观看| 欧美精品在线一区二区| 欧美大片日本大片免费观看| 精品久久久久久久久久久久久久久| 精品国产乱码久久久久久久久 | 91丝袜美腿高跟国产极品老师 | 欧美男男青年gay1069videost| 欧美久久高跟鞋激| 精品久久久三级丝袜| 久久久久99精品一区| 国产精品免费人成网站| 亚洲人精品午夜| 香蕉久久一区二区不卡无毒影院| 美女脱光内衣内裤视频久久网站 | 亚洲成精国产精品女| 日本欧美一区二区三区| 国产一区二区久久| 91色porny蝌蚪| 91精品国产综合久久精品性色 | 国产精品久久毛片a| 一区二区三区在线影院| 免费高清视频精品| 国产a级毛片一区| 欧美三区免费完整视频在线观看| 91麻豆精品国产91久久久久久久久| 欧美r级电影在线观看| 亚洲三级在线免费| 秋霞国产午夜精品免费视频| 国产成人精品免费| 欧美亚洲综合网| 精品99一区二区三区| 国产精品麻豆视频| 琪琪久久久久日韩精品| 成人综合在线视频| 91精品免费在线观看| 亚洲国产成人自拍| 丝袜a∨在线一区二区三区不卡| 黄网站免费久久| 一本色道久久加勒比精品| 欧美一区中文字幕| 日韩毛片精品高清免费| 久久疯狂做爰流白浆xx| 欧美中文字幕一区| 国产网红主播福利一区二区| 亚洲午夜久久久久久久久久久| 国产高清久久久| 欧美男女性生活在线直播观看| 国产精品久久免费看| 美国av一区二区| 欧日韩精品视频| 欧美激情综合五月色丁香| 日本色综合中文字幕| 日本韩国视频一区二区| 亚洲国产精品黑人久久久| 蜜桃传媒麻豆第一区在线观看| 色综合久久中文综合久久97| 久久人人97超碰com| 日本伊人精品一区二区三区观看方式 | 一区二区三区高清不卡| 国产精品影音先锋| 制服丝袜在线91| 亚洲精品国产精品乱码不99| 成人一区二区在线观看| 精品久久久三级丝袜| 午夜欧美在线一二页| 在线观看视频一区二区| 国产精品欧美一区二区三区| 国内精品久久久久影院薰衣草| 91精品国产综合久久香蕉麻豆| 亚洲国产日韩a在线播放| eeuss鲁一区二区三区| 久久久久久9999| 国产一区欧美一区| 日韩精品一区二区三区中文不卡| 午夜视黄欧洲亚洲| 欧美日韩免费电影| 亚洲一区二区偷拍精品| 色哟哟在线观看一区二区三区| 国产精品久久午夜| 成人动漫在线一区| 亚洲国产高清不卡| 成人中文字幕电影| 国产人成亚洲第一网站在线播放| 国内外精品视频| 久久久久国产精品人| 国产激情一区二区三区| 国产亚洲一区字幕| 懂色av一区二区三区免费看| 国产欧美日韩在线视频| 成人av中文字幕| 亚洲欧洲精品一区二区三区不卡| eeuss影院一区二区三区| 1024成人网色www| 91福利在线免费观看| 亚洲福利一区二区三区| 欧美精品久久天天躁| 日本美女一区二区| 欧美mv和日韩mv的网站| 激情五月婷婷综合网| 国产亚洲成aⅴ人片在线观看| 国产成人a级片| 国产精品久久久久毛片软件| 色偷偷久久人人79超碰人人澡| 亚洲在线免费播放| 91精品国产综合久久福利软件| 久久精品国产99| 国产日韩精品一区二区三区| 99精品热视频| 亚洲成人资源网| 精品国产sm最大网站| 成人精品视频一区二区三区| 伊人性伊人情综合网| 777奇米成人网| 国产一区在线视频| 亚洲同性同志一二三专区| 欧美午夜精品久久久久久超碰| 美洲天堂一区二卡三卡四卡视频| 久久精品人人做人人综合| 色综合中文字幕国产| 亚洲综合999| 精品少妇一区二区三区免费观看| 成人性色生活片免费看爆迷你毛片| 亚洲欧美日本韩国| 91精品国产乱| 成人一二三区视频| 日韩在线一二三区| 国产清纯在线一区二区www| 欧美在线一二三| 国产麻豆精品一区二区| 亚洲一区二区中文在线| 久久久亚洲高清| 91国产视频在线观看| 韩国女主播成人在线| 亚洲精选一二三| 日韩精品一区二区三区视频播放| 成人午夜免费视频| 日韩高清国产一区在线| 亚洲国产精品99久久久久久久久| 欧美福利电影网| 成人av在线网| 蜜桃视频第一区免费观看| 国产精品高潮久久久久无| 91精品一区二区三区在线观看| kk眼镜猥琐国模调教系列一区二区 | 久久一区二区三区四区| 欧美亚洲综合网| 菠萝蜜视频在线观看一区| 精品在线免费视频| 午夜伦欧美伦电影理论片|