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

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

?? trancoordidlg.cpp

?? 一個AO關于批量轉換坐標系統的源碼 GIS平臺:ArcGis9.0,開發包:ArcObject
?? CPP
字號:
// TranCoordiDlg.cpp : implementation file
//

#include "stdafx.h"
#include "TranCoordi.h"
#include "TranCoordiDlg.h"
#include "TextProgressDll.h"
//#include <esriCatalogUI.tlh>

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CTranCoordiDlg dialog

CTranCoordiDlg::CTranCoordiDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CTranCoordiDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CTranCoordiDlg)
	m_strDataBaseName = _T("");
	m_strRefName = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CTranCoordiDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CTranCoordiDlg)
	DDX_Text(pDX, IDC_EDITDATABASE, m_strDataBaseName);
	DDX_Text(pDX, IDC_EDITCOORD, m_strRefName);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CTranCoordiDlg, CDialog)
	//{{AFX_MSG_MAP(CTranCoordiDlg)
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BTNOPENDATABASE, OnBtnOpenDatabase)
	ON_BN_CLICKED(IDC_BTNOPENCOOR, OnBtnOpenCoor)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CTranCoordiDlg message handlers

BOOL CTranCoordiDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CTranCoordiDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CTranCoordiDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CTranCoordiDlg::OnBtnOpenDatabase() 
{
		IGxDialogPtr					ipGxDialog = NULL;
		IGxObjectFilterPtr				ipGxObjectFilter = NULL;
		IEnumGxObjectPtr				ipEnumGxObject = NULL;
		IGxObjectPtr					ipGxObject = NULL;
		IWorkspaceNamePtr				ipWksName = NULL;
		VARIANT_BOOL					bResult;
		HRESULT							hr;	
		BSTR							bstrDataBaseName;

	UpdateData(TRUE);
	GetDlgItem(IDC_EDITDATABASE)->EnableWindow(TRUE);
	GetDlgItem(IDC_EDITDATABASE)->SetWindowText("");
	
	hr = ipGxDialog.CreateInstance(CLSID_GxDialog);
	if(FAILED(hr)) 		return;

	hr = ipGxObjectFilter.CreateInstance(CLSID_GxFilterWorkspaces);
	if(FAILED(hr)) 		return;
	
	ipGxDialog->putref_ObjectFilter(ipGxObjectFilter);
	ipGxDialog->put_AllowMultiSelect(VARIANT_TRUE);
	ipGxDialog->put_Title(CComBSTR("選擇ArcGis數據庫"));	
	
	hr = ipGxDialog->DoModalOpen(0,&ipEnumGxObject,&bResult);
	if(FAILED(hr)) 						return;
	if(bResult == VARIANT_FALSE)		return;	
	
	// 獲得地理數據庫名稱
	hr = ipEnumGxObject->Reset();	
	while(!ipEnumGxObject->Next(&ipGxObject))
	{
		ipGxObject->QueryInterface(IID_IGxDatabase,(void **)&m_ipGxDatabase);
		if(m_ipGxDatabase !=0)	
		{
			hr = m_ipGxDatabase->get_WorkspaceName(&ipWksName);
			if(FAILED(hr))						return;

			ipWksName->get_PathName(&bstrDataBaseName);
			m_strDataBaseName = bstrDataBaseName;
		}
	}
	GetDlgItem(IDC_EDITDATABASE)->EnableWindow(FALSE);
	UpdateData(FALSE);
}



void CTranCoordiDlg::OnBtnOpenCoor() 
{
		IGxDialogPtr					ipGxDialog			= NULL;
		IGxObjectFilterPtr				ipGxObjectFilter	= NULL;
		IEnumGxObjectPtr				ipEnumGxRefCoordi	= NULL;
		IGxObjectPtr					ipGxObject			= NULL;
		
		VARIANT_BOOL					bResult	= FALSE	;
		HRESULT							hr		= 1		;	
		BSTR							bstrRefPath		;
	
	UpdateData(TRUE);
	GetDlgItem(IDC_EDITCOORD)->EnableWindow(TRUE);
	GetDlgItem(IDC_EDITCOORD)->SetWindowText("");

	hr = ipGxDialog.CreateInstance(CLSID_GxDialog);
	if(FAILED(hr)) 		return;

	hr = ipGxObjectFilter.CreateInstance(CLSID_GxFilterSpatialReferences);
	if(FAILED(hr)) 		return;
	
	ipGxDialog->putref_ObjectFilter(ipGxObjectFilter);
	ipGxDialog->put_AllowMultiSelect(VARIANT_TRUE);
	ipGxDialog->put_Title(CComBSTR("選擇坐標系"));	
	
	hr = ipGxDialog->DoModalOpen(0,&ipEnumGxRefCoordi,&bResult);
	if(FAILED(hr)) 
		return;
	if(bResult == VARIANT_FALSE)
		return;	

	hr = ipEnumGxRefCoordi->Reset();
	while(!ipEnumGxRefCoordi->Next(&ipGxObject))
	{
		IGxPrjFilePtr ipGxRefFold(ipGxObject);
		if(ipGxRefFold !=0)	
		{
			hr =ipGxRefFold->get_SpatialReference(&m_ipSpatialRef);
			m_ipSpatialRef->get_Name(&bstrRefPath);
			if(FAILED(hr))				return;

			m_strRefName = bstrRefPath;
		}
	 
	}

	GetDlgItem(IDC_EDITCOORD)->EnableWindow(FALSE);
	UpdateData(FALSE);
}

void CTranCoordiDlg::OnOK() 
{
		IWorkspacePtr				ipWks = NULL;
		IDEBrowseOptionsPtr			pEDBrsPpt =NULL;
		IWorkspaceDataElementsPtr	pWksDateElemt =NULL;
		IDataElementPtr				pDataEmt = NULL;
		IDEGeoDatasetPtr			pDGSetEmt=NULL;
		IGeoDatasetSchemaEditPtr	ipGeoDataSetEdit;
		IEnumDatasetPtr				pEnumData=NULL;
		IDatasetPtr					pDataSet =NULL;
		HRESULT						hr;	
		long						rtn = 1;
		int							i=0;
	// 0.設置參數
	hr = pEDBrsPpt.CreateInstance(CLSID_DEBrowseOptions);
	if(FAILED(hr)) 		{rtn = 0; goto Tran_End;}
	hr = pEDBrsPpt->put_RetrieveFullProperties(TRUE);
	hr = pEDBrsPpt->put_ExpandType(esriDEExpandDescendants);
	hr = pEDBrsPpt->put_RetrieveMetadata(TRUE);
	
	hr = m_ipGxDatabase->get_Workspace(&ipWks);
	if(FAILED(hr)) 		{rtn = 0; goto Tran_End;}

	// 1.獲得地理數據庫下的所有數據集
	hr = ipWks->get_Datasets(esriDTFeatureDataset,&pEnumData);
	if(FAILED(hr)) 		{rtn = 0; goto Tran_End;}
	
	// 2.獲得數據集元數據
	hr = _nCreatePercentWnd("批量轉換進行中...",1);
	pWksDateElemt=ipWks;
	while(!pEnumData->Next(&pDataSet))
		{
		i++;
		_nDispPercent((short)i*100/20);
		ipGeoDataSetEdit=pDataSet;
		
		hr = pWksDateElemt->GetDatasetDataElement(pDataSet,pEDBrsPpt,&pDataEmt);
		if(FAILED(hr)) 		{rtn = 0; goto Tran_End;}	
		pDataEmt->put_MetadataRetrieved(TRUE);
		pDGSetEmt = pDataEmt;
		
		//3.更改坐標系
		hr = pDGSetEmt->putref_SpatialReference(m_ipSpatialRef);
		hr = ipGeoDataSetEdit->AlterSpatialReference(m_ipSpatialRef);
		}
		_nDestroyPercentWnd();
Tran_End:
		if (rtn ==0)
			MessageBox("坐標系統修改失敗!","提示");
		else
			MessageBox("坐標系統修改成功!","提示");
	return;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合久久综合网97色综合 | 色狠狠综合天天综合综合| 精品日韩欧美一区二区| 久久久久久久电影| 午夜精品久久久久久久久久| 国产99久久久国产精品潘金| 5566中文字幕一区二区电影| 国产精品成人午夜| 精品一区二区三区免费观看| 91美女蜜桃在线| 国产亚洲精品福利| 日韩精品视频网| 日本高清无吗v一区| 国产女人aaa级久久久级 | 久久精品国产色蜜蜜麻豆| 99精品欧美一区| 久久伊99综合婷婷久久伊| 亚洲成人在线免费| 91啦中文在线观看| 中文字幕在线一区| 成人爽a毛片一区二区免费| 日韩视频在线永久播放| 午夜视频在线观看一区| 91成人在线观看喷潮| 中国av一区二区三区| 国产精品白丝av| 精品国产乱码久久久久久影片| 午夜av一区二区三区| 欧美日韩三级一区二区| 亚洲精品美国一| 91麻豆6部合集magnet| 国产精品美女久久福利网站| 成人动漫中文字幕| 最新欧美精品一区二区三区| 成人高清视频在线| 国产精品美女一区二区三区 | 久久精品在线观看| 激情六月婷婷久久| 久久夜色精品国产噜噜av| 精品在线播放免费| 久久久国产综合精品女国产盗摄| 久久91精品久久久久久秒播| 精品理论电影在线观看| 久久国产精品一区二区| 久久久久久夜精品精品免费| 国产老女人精品毛片久久| 国产亚洲女人久久久久毛片| 成人性视频免费网站| **性色生活片久久毛片| 色天使久久综合网天天| 午夜精品一区二区三区电影天堂| 在线不卡一区二区| 韩国午夜理伦三级不卡影院| 国产亚洲欧美激情| 在线这里只有精品| 日韩成人午夜电影| 久久免费国产精品| 色婷婷av一区二区三区之一色屋| 亚洲h动漫在线| 精品国产免费一区二区三区四区| 国产精品一区二区三区99| 国产精品久久久久久久久久久免费看 | 成人美女在线观看| 亚洲精品国产无套在线观 | 91欧美一区二区| 午夜在线成人av| 久久婷婷久久一区二区三区| 高清国产一区二区三区| 一区二区三区影院| 欧美不卡一区二区| 99久久精品国产一区| 日韩在线卡一卡二| 国产精品日韩精品欧美在线 | 99久久精品国产观看| 亚洲一区二三区| 久久综合网色—综合色88| av一二三不卡影片| 麻豆免费精品视频| 亚洲色图制服丝袜| 精品国产欧美一区二区| 在线中文字幕一区| 岛国一区二区在线观看| 日本午夜一区二区| 国产精品灌醉下药二区| 在线综合亚洲欧美在线视频| 99视频国产精品| 日本不卡一二三区黄网| 亚洲婷婷综合久久一本伊一区 | 国产精品狼人久久影院观看方式| 精品视频一区二区不卡| 国产电影精品久久禁18| 日本欧美一区二区在线观看| 亚洲另类色综合网站| 精品sm在线观看| 欧美老年两性高潮| 一本久久精品一区二区| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 欧美日韩第一区日日骚| 91美女片黄在线观看| 国产成人一区在线| 精品一区二区三区av| 亚洲成人av一区二区三区| 伊人开心综合网| 国产精品日产欧美久久久久| 国产亚洲一区字幕| 久久亚洲春色中文字幕久久久| 欧美精品vⅰdeose4hd| 在线观看日韩av先锋影音电影院| 成人手机在线视频| 成人综合在线观看| 国产裸体歌舞团一区二区| 久久av资源网| 裸体健美xxxx欧美裸体表演| 日韩黄色免费电影| 丝袜亚洲另类丝袜在线| 亚洲国产精品久久不卡毛片 | 欧美性色黄大片手机版| 色婷婷久久一区二区三区麻豆| 99国产精品国产精品毛片| 成人app在线| www.欧美亚洲| 一本色道久久加勒比精品| 91网站最新地址| 一本久久精品一区二区| 91极品美女在线| 欧美日韩久久久一区| 欧美日韩亚州综合| 91麻豆精品国产91久久久久久久久| 欧美久久久久久蜜桃| 欧美日韩中文字幕一区| 337p亚洲精品色噜噜| 91精品国产手机| 精品国产一区二区三区不卡 | 欧美日韩精品电影| 欧美精品1区2区3区| 日韩欧美激情一区| 久久色在线观看| 国产精品伦一区| 亚洲一区二区三区中文字幕| 亚洲国产精品尤物yw在线观看| 日韩有码一区二区三区| 国产一区高清在线| eeuss鲁一区二区三区| 在线精品观看国产| 欧美一区二区二区| 国产精品嫩草影院av蜜臀| 亚洲欧美另类图片小说| 日本vs亚洲vs韩国一区三区二区| 国产精品综合网| 色婷婷一区二区| 日韩久久免费av| 国产精品素人视频| 天天综合日日夜夜精品| 国产精品乡下勾搭老头1| 色婷婷香蕉在线一区二区| 日韩一二三区视频| 亚洲欧美经典视频| 国产一区二区三区| 在线亚洲人成电影网站色www| 欧美放荡的少妇| 国产精品乱人伦中文| 男人的j进女人的j一区| 99精品视频一区二区| 精品国产污污免费网站入口 | 亚洲色图欧美在线| 精品亚洲国内自在自线福利| av亚洲精华国产精华精华| 日韩午夜激情视频| 亚洲图片欧美色图| av不卡免费电影| 久久婷婷综合激情| 日韩有码一区二区三区| 色综合久久久久网| 欧美国产精品一区| 美国毛片一区二区| 精品视频一区三区九区| 亚洲色欲色欲www| 成人午夜视频福利| 日韩精品一区二区三区四区| 亚洲一区国产视频| 色天天综合久久久久综合片| 中文字幕高清一区| 久久99精品国产麻豆婷婷洗澡| 欧美美女一区二区在线观看| 亚洲天堂福利av| 成人免费毛片嘿嘿连载视频| 欧美岛国在线观看| 日本麻豆一区二区三区视频| 91高清在线观看| 一区二区三区在线视频播放| 风间由美一区二区av101| 精品精品国产高清a毛片牛牛| 天堂成人免费av电影一区| 欧美三级日韩在线| 亚洲不卡在线观看| 欧美日韩情趣电影| 亚洲va韩国va欧美va精品| 欧美日韩亚洲综合在线 | 中文字幕一区二区三区不卡| 国产成人综合亚洲网站|