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

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

?? geoobj.cpp

?? GemoMedia 應用 演示了其使用方法
?? CPP
字號:
// GeoObj.cpp: implementation of the CGeoObj class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "SvfToGeoMedia.h"
#include "GeoObj.h"
#include "ADOConn.h"

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

extern ADOConn*  G_pADOConn; 
extern DGMConnectionPtr G_ptrDVIConnection ;
extern DGMGeometryStorageServicePtr G_ptrGSS;

extern CString GetFieldStr(char* str,ADODB::_RecordsetPtr pDS);
extern void SendMsg(CString str);

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CGeoObj::CGeoObj():m_nID(-1),m_strGeoCode(""),m_strTable("")
,m_strType("")
{

}

CGeoObj::~CGeoObj()
{

}

//寫地理對象到數據庫
bool CGeoObj::WriteGeoObjToDataBase()
{
	//創(chuàng)建地理對象
	//IDispatch* objGeom;
	_DGMOrientedPointGeometryPtr ptrOrientPoint;
	_DGMPolylineGeometryPtr ptrLine;
	_DGMPolygonGeometryPtr ptrPolygon;
	_DGMTextPointGeometryPtr ptrTextPoint;

	m_strTable.TrimLeft() ;
	m_strTable.TrimRight();
	m_strType.MakeUpper();

	if (m_strType=="POINT")
	{
		//_DGMOrientedPointGeometryPtr ptrOrientPoint;
		ptrOrientPoint.CreateInstance(__uuidof(OrientedPointGeometry));

		ptrOrientPoint->Orientation->I = 1;
		ptrOrientPoint->Orientation->J= 0;
		ptrOrientPoint->Orientation->K= 0;		
		
		Node node = *m_PosList.begin();
		ptrOrientPoint->Origin->X =node.fPosX;
		ptrOrientPoint->Origin->Y =node.fPosY;
		ptrOrientPoint->Origin->Z =node.fPosH;	
		
		//objGeom = ptrOrientPoint;
	}
	
	//線
	if (m_strType=="LINE")
	{
		//_DGMPolylineGeometryPtr ptrLine;
		ptrLine.CreateInstance(__uuidof(PolylineGeometry));
		
		for(list<Node>::const_iterator item = m_PosList.begin();item!= m_PosList.end();item++)
		{
			Node node = *item;
			_DGMPointPtr pPoint;
			pPoint.CreateInstance("GeoMedia.Point");
			pPoint->X = node.fPosX;
			pPoint->Y = node.fPosY;
			pPoint->Z = node.fPosH;
			
			ptrLine->Points->Add(pPoint);
		}
		//objGeom = ptrLine;
	}

	//面
	if (m_strType=="POLYGON")
	{		
		//_DGMPolygonGeometryPtr ptrPolygon;
		ptrPolygon.CreateInstance(__uuidof(PolygonGeometry));
		
		for(list<Node>::const_iterator item = m_PosList.begin();item!= m_PosList.end();item++)
		{
			Node node = *item;
			_DGMPointPtr pPoint;
			pPoint.CreateInstance("GeoMedia.Point");
			pPoint->X = node.fPosX;
			pPoint->Y = node.fPosY;
			pPoint->Z = node.fPosH;
			
			ptrPolygon->Points->Add(pPoint);
		}
		
		//最后加入起點
		Node Nodefirst = *m_PosList.begin();
		_DGMPointPtr pPoint;
		pPoint.CreateInstance("GeoMedia.Point");
		pPoint->X = Nodefirst.fPosX;
		pPoint->Y = Nodefirst.fPosY;
		pPoint->Z = Nodefirst.fPosH;

		ptrPolygon->Points->Add(pPoint);

		//objGeom = ptrPolygon;
	}

	//注記
	if (m_strType=="ANNO")
	{
		//_DGMTextPointGeometryPtr ptrTextPoint;
		ptrTextPoint.CreateInstance(__uuidof(TextPointGeometry));

		Node node = *m_PosList.begin();

		ptrTextPoint->Origin->X = node.fPosX;
		ptrTextPoint->Origin->Y = node.fPosY;
		ptrTextPoint->Origin->Z = node.fPosH;

		ptrTextPoint->Alignment = gmaBottomLeft;
		ptrTextPoint->Normal->I = 0;
		ptrTextPoint->Normal->J = 0;
		ptrTextPoint->Normal->K = 1;
		
		//注記內容
		CString strcontext("");
		//字高
		double  dfontH=0;
		//轉角
		double dfontR =0;
		//字體
		CString strFont("");
		   
		for (list<Attr>::const_iterator item = m_AttrList.begin(); item!= m_AttrList.end();item++)
		{
			Attr attr = *item;
			CString strAttrName(attr.strAttrName.c_str());
			if (strAttrName == "注記")
				strcontext = attr.strAttr.c_str();

			if (strAttrName == "字高")
				dfontH = atof(attr.strAttr.c_str());

			if (strAttrName =="轉角")
				dfontR = atof(attr.strAttr.c_str());

			if (strAttrName =="字體")
				strFont = attr.strAttr.c_str();
		}

		if (ptrTextPoint->Format == 0 )
		{
			ptrTextPoint->RichText = _bstr_t(strcontext);
		}
		else
		{
			ptrTextPoint->text = _bstr_t(strcontext);
		}
		
		ptrTextPoint->Rotation = dfontR;
		
		//objGeom = ptrTextPoint;
	}
	
	//添加地理對象到數據表中
	//訪問數據庫
	OriginatingPipePtr ptrOrigPipe;
	G_ptrDVIConnection->CreateOriginatingPipe(&ptrOrigPipe);
	ptrOrigPipe->put_GeometryFieldName(_variant_t("Geometry"));
	ptrOrigPipe->put_Table(_bstr_t(m_strTable));
				
	GRecordsetPtr ptrAddRs;
	ptrOrigPipe->get_OutputRecordset(&ptrAddRs);
		
	////////////////////////////////////////////////////////////////
	//取得目前最大記錄
	long temp_v=0;
	if (!ptrAddRs->_EOF)
	{
		ptrAddRs->MoveLast();
		for(int i = 0;i < ptrAddRs->GFields->Count;i++)
		{
			BSTR fieldname;
			ptrAddRs->GFields->Item[(long)i]->get_Name(&fieldname);
			CString strfieldname = fieldname;
			//if(strfieldname == "GMIPrimaryKey") 
			if(strfieldname == "ID") 
				temp_v = ptrAddRs->GFields->Item[(long)i]->Value;
		}
	}
	
	temp_v++;
	
	list<Attr>::const_iterator item_attr = m_AttrList.begin();

	ptrAddRs->AddNew();
	int count = ptrAddRs->GFields->Count;
	for(int i = 0;i < ptrAddRs->GFields->Count;i++)
	{
		BSTR fieldname;
		ptrAddRs->GFields->Item[(long)i]->get_Name(&fieldname);
		CString strfieldname = fieldname;
		if(strfieldname == "Geometry")
		{
			if (m_strType=="POINT")
			{
				G_ptrGSS->SetGeometry(ptrAddRs->GFields->Item[(long)i],ptrOrientPoint);
			}
		
			if (m_strType=="LINE")
			{
				G_ptrGSS->SetGeometry(ptrAddRs->GFields->Item[(long)i],ptrLine);
			}

			if (m_strType=="POLYGON")
			{
				G_ptrGSS->SetGeometry(ptrAddRs->GFields->Item[(long)i],ptrPolygon);
			}

			if (m_strType=="ANNO")
			{
				G_ptrGSS->SetGeometry(ptrAddRs->GFields->Item[(long)i],ptrTextPoint);
			}

		}	else if(strfieldname == "ID")
			ptrAddRs->GFields->Item[(long)i]->put_Value(_variant_t((long)temp_v));		
		//else if(strfieldname == "Geometry_sk")
		//	ptrAddRs->GFields->Item[(long)i]->put_Value(_variant_t("1Bm,zRm{"));
		else if (item_attr != m_AttrList.end())
		{
			Attr node_attr = *item_attr;
			ptrAddRs->GFields->Item[(long)i]->put_Value(_variant_t(_bstr_t(node_attr.strAttr.c_str())));

			item_attr++;
		}


	}
	ptrAddRs->Update();	
	ptrAddRs->Close();
	
	//
	m_nID = temp_v;

	return true;
}

//得到地理對象對應的數據表表名
bool CGeoObj::GetTableName()
{
	try
	{	
		if (G_pADOConn==NULL)
		{
			G_pADOConn = new ADOConn;
		}
		else
		{
			if (!G_pADOConn->m_bConnect)
			{
				if (!G_pADOConn->OnInitADOAcess("DataConv.mdb"))
				{
					AfxMessageBox("連接數據庫失敗!");
					return false;
				}
			}
		}
	
		

		CString strGeoCode(m_strGeoCode.c_str());
		CString strSQL = "Select * from SvfToGeoMedia where svf代碼='"+strGeoCode+"'";
		ADODB::_RecordsetPtr pDS = G_pADOConn->GetRecordSet((_bstr_t)strSQL);
		
		if (pDS->adoEOF)
		{
			SendMsg("在SvfToGeoMedia表中沒有查到Svf代碼為"+strGeoCode+"對應的表!");
			//AfxMessageBox("在SvfToGeoMedia表中沒有查到Svf代碼為"+strGeoCode+"對應的表!");			
			pDS->Close();
			return false;
		}

		m_strTable = GetFieldStr("數據表",pDS);
		m_strType  = GetFieldStr("地物類型",pDS);

		pDS->Close();

		//檢查表是否存在

		return true;
	}
	catch (CException* e)
	{
		e->Delete();
		
	}		
}

//從地理數據庫中刪除地理對象
bool CGeoObj::DelGeoObj()
{
	//G_ptrDVIConnection

	return true;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产午夜亚洲精品不卡| 色婷婷国产精品综合在线观看| 国产成人免费9x9x人网站视频| a在线播放不卡| 色88888久久久久久影院按摩| 欧美精品久久一区二区三区| 欧美成人性福生活免费看| 国产精品久久久久影院老司| 亚洲午夜精品在线| 国产一区二区三区在线观看精品 | 日韩亚洲欧美成人一区| 国产午夜精品在线观看| 亚洲一区二区三区不卡国产欧美| 婷婷丁香久久五月婷婷| 国产成人午夜视频| 欧美精品日日鲁夜夜添| 日韩成人精品在线| 国产成人精品免费| 欧美老女人第四色| 欧美经典一区二区| 日韩福利电影在线观看| a4yy欧美一区二区三区| 日韩一级二级三级精品视频| 亚洲视频一区在线观看| 欧美a级理论片| 91蝌蚪porny| 久久午夜色播影院免费高清| 亚洲一区二区三区四区五区中文| 国产一区 二区| 欧美一区午夜视频在线观看| 亚洲欧洲成人自拍| 韩国精品主播一区二区在线观看 | 亚洲精品美国一| 韩国av一区二区三区在线观看| 欧美这里有精品| 国产精品久久久久影视| 国产一区二区毛片| 91精品福利在线一区二区三区| 一区二区三区在线视频观看58| 国产精品影视网| 欧美一区二区三区视频免费 | 欧美日韩在线直播| 成人欧美一区二区三区视频网页| 国产精品一品视频| 日韩欧美一级在线播放| 丝袜美腿亚洲综合| 在线视频一区二区三| 国产精品国产精品国产专区不蜜 | 欧美激情一区二区三区四区| 亚洲免费av网站| 成人深夜视频在线观看| 精品久久久久久久人人人人传媒 | 精品视频123区在线观看| 国产精品久久久久三级| 国产传媒一区在线| 日韩三区在线观看| 日本不卡123| 欧美午夜电影网| 伊人性伊人情综合网| 粉嫩aⅴ一区二区三区四区五区| 欧美成人精品3d动漫h| 首页综合国产亚洲丝袜| 欧美日产国产精品| 亚洲天堂中文字幕| 99视频精品免费视频| 成人精品视频一区| 欧美一区二区三区成人| 日本特黄久久久高潮| 色综合久久88色综合天天免费| 国产欧美视频一区二区三区| 日本亚洲电影天堂| 日韩欧美一级二级三级久久久| 午夜精品爽啪视频| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 91麻豆免费观看| 国产精品欧美经典| 成人免费电影视频| 中文字幕制服丝袜一区二区三区| 成人小视频免费在线观看| 久久精品日韩一区二区三区| 国产成人在线免费| 亚洲欧洲国产日韩| 色香蕉成人二区免费| 一区二区在线免费| 在线播放日韩导航| 日本大胆欧美人术艺术动态| 日韩视频一区二区三区在线播放| 亚洲成a人片在线观看中文| 色综合网站在线| 午夜免费欧美电影| 欧美日韩精品欧美日韩精品一| 亚洲动漫第一页| 日韩一区二区三区免费观看| 久久精品国产澳门| 欧美激情一区二区三区蜜桃视频| 成人av网站在线观看免费| 亚洲欧美电影一区二区| 欧美日韩在线精品一区二区三区激情 | 国产欧美日韩视频一区二区| 99国产精品99久久久久久| 一区二区高清在线| 欧美日韩精品欧美日韩精品一| 日本va欧美va欧美va精品| 91精品国产综合久久蜜臀| 久草中文综合在线| 国产精品传媒在线| 欧美日韩一区视频| 精品一区二区久久| 国产日本一区二区| 欧洲激情一区二区| 麻豆成人av在线| 中文字幕第一区综合| 在线免费观看成人短视频| 视频在线观看国产精品| 久久久精品免费网站| 91黄色免费网站| 另类成人小视频在线| 久久综合色播五月| 91看片淫黄大片一级在线观看| 一级特黄大欧美久久久| 欧美最新大片在线看| 久久99精品一区二区三区三区| 国产欧美日韩在线视频| 欧美综合在线视频| 一级精品视频在线观看宜春院 | 日本中文字幕一区二区有限公司| 国产亚洲精品aa| 欧美色大人视频| 国产精品综合二区| 亚洲午夜久久久久久久久电影院| 久久综合九色综合97婷婷| 欧日韩精品视频| 成人午夜精品在线| 蜜臀av亚洲一区中文字幕| 亚洲人成网站在线| 欧美亚洲自拍偷拍| 国产大陆精品国产| 麻豆久久一区二区| 亚洲精品亚洲人成人网| 欧美成人伊人久久综合网| 欧美日韩在线精品一区二区三区激情| 国产麻豆视频精品| 亚洲国产精品久久艾草纯爱| 亚洲国产精品精华液2区45| 在线电影一区二区三区| 91美女蜜桃在线| 岛国精品在线播放| 久久成人av少妇免费| 日一区二区三区| 夜夜嗨av一区二区三区四季av| 国产三级欧美三级日产三级99| 欧美日韩性生活| 欧洲精品一区二区| 波多野结衣在线aⅴ中文字幕不卡| 麻豆91小视频| 五月天丁香久久| 亚洲天堂2016| 中文字幕中文字幕一区二区| 久久这里都是精品| 日韩精品一区二区三区老鸭窝 | 日韩av网站在线观看| 亚洲欧美日韩综合aⅴ视频| 2022国产精品视频| 日韩午夜电影av| 欧美一区二区视频网站| 欧美性猛片aaaaaaa做受| 色综合久久综合网欧美综合网| 青青草国产精品亚洲专区无| 亚洲电影你懂得| 国产欧美日韩视频一区二区| 2024国产精品| 久久久久久久久久久黄色| 日韩午夜三级在线| 欧美日韩国产综合一区二区| 欧洲精品一区二区| 欧美色图一区二区三区| 在线观看国产精品网站| 色www精品视频在线观看| 在线观看日产精品| 91蝌蚪porny九色| 国产成人精品网址| 韩国在线一区二区| 日韩精品成人一区二区三区| 亚洲v中文字幕| 午夜欧美电影在线观看| 国产亚洲欧美在线| 国产欧美日韩视频在线观看| 久久先锋影音av鲁色资源| 久久日韩精品一区二区五区| 精品国产91九色蝌蚪| www激情久久| 欧美精品一区二区高清在线观看| 欧美精品tushy高清| 欧美日韩在线播放| 日韩一区二区中文字幕| 这里只有精品视频在线观看| 91精品国产美女浴室洗澡无遮挡| 这里只有精品99re| 欧美一区二区三区在| 日韩欧美激情一区|