構文
BOOL GetSiteUpDown(VARIANT * vVertex,
BYTE * byInputType, double * dPolygonHeight, USHORT * uBaseLineIndex,
double
* dBaseLineHeight, double * dGradient, VARIANT * vSelectPointArray,
VARIANT * vZPos);
(JavaScript用) string GetSiteUpDownJS();
カレントのオブジェクトが、敷地高低差オブジェクトの場合、その情報を取得します。
パラメータ
vVertex
(x, y) 頂点列。型は VT_R8 | VT_ARRAY にしてください。vVertex.parrayは不要になったら、SafeArrayDestroyで解放してください。
byInputType
高さの指定方法。次のいずれかの値を指定できます。
- 0面の高さを指定。
- 1辺と勾配を指定。
- 23点の高さを指定。
dPolygonHeight
高さ。単位ミリ。
uBaseLineIndex
勾配の基準となる辺。
dBaseLineHeight
基準となる辺の高さ。単位ミリ。
dGradient
勾配(%)。
vSelectPointArray
高さを決定する頂点配列。配列要素は、3。型は、VT_UI2 | VT_ARRAY
にしてください。vSelectPointArray.parrayは不要になったら、SafeArrayDestroyで解放してください。
vZPos
高さの配列。型は、VT_R8 | VT_ARRAY にしてください。vZPos.parrayは不要になったら、SafeArrayDestroyで解放してください。
戻り値
敷地敷地高低差オブジェクトの情報を取得できた場合 0 以外を返します。できなかった場合は 0 を返します。
使用例
// 間取りオブジェクトへ接続
CMadoriDoc * m_MadoriDoc = new CMadoriDoc();
CLSIDFromProgID (L"MyHomeDesignerMadori.MadoriDoc", &clsid);
GetActiveObject (clsid, NULL, &pUnk);
pUnk->QueryInterface (IID_IDispatch, (void**)(&pDisp));
m_MadoriDoc->AttachDispatch (pDisp);
// 列挙する
long lRet = m_MadoriDoc->GetTopObject();
if(lRet == 0) AfxMessageBox(TEXT("何もない"));
while(lRet){
ULONG uType = m_MadoriDoc->GetCurrentObjectType();
short nLayer = m_MadoriDoc->GetCurrentObjectLayer();
CString strMsg;
strMsg.Format(TEXT("[%X]type[%d]layer[%d]"), lRet, uType,nLayer);
AfxMessageBox(strMsg);
lRet = m_MadoriDoc->GetNextObject();
switch(uType){
case 30: // geo feature
{
VARIANT vVertex;
unsigned char byInputType;
double dPolygonHeight;
unsigned short uBaseLineIndex;
double dBaseLineHeight, dGradient;
VARIANT vSelectPointArray, vZPos;
vVertex.vt = VT_R8 | VT_ARRAY;
vVertex.parray = NULL;
vSelectPointArray.vt = VT_UI2 | VT_ARRAY;
vSelectPointArray.parray = NULL;
vZPos.vt = VT_R8 | VT_ARRAY;
vZPos.parray = NULL;
m_MadoriDoc->GetSiteUpDown(&vVertex, &byInputType, &dPolygonHeight, &uBaseLineIndex, &dBaseLineHeight,
&dGradient, &vSelectPointArray, &vZPos);
ULONG uVertex = 0;
if(vVertex.parray){
uVertex = vVertex.parray->rgsabound[0].cElements;
}
ULONG uSelectPointArray = 0;
if(vSelectPointArray.parray){
uSelectPointArray = vSelectPointArray.parray->rgsabound[0].cElements;
}
ULONG uZPos = 0;
if(vZPos.parray){
uZPos = vZPos.parray->rgsabound[0].cElements;
}
strMsg.Format(TEXT("geo feature v[%u]type[%d]h[%lf]base[%u]lineH[%lf]gra[%lf]point[%u]z[%u]"),
uVertex/2, byInputType, dPolygonHeight, uBaseLineIndex, dBaseLineHeight,
dGradient, uSelectPointArray, uZPos);
AfxMessageBox(strMsg);
if(uVertex > 0){
double * pVar;
SafeArrayAccessData(vVertex.parray, (void**)&pVar);
for(ULONG u = 0; u < uVertex; u+=2){
strMsg.Format(TEXT("Vertex %u[%lf,%lf]"), u/2, pVar[u], pVar[u+1]);
AfxMessageBox(strMsg);
}
SafeArrayUnaccessData(vVertex.parray);
}
if(vVertex.parray) SafeArrayDestroy(vVertex.parray);
if(uSelectPointArray > 0){
unsigned short * pVar;
SafeArrayAccessData(vSelectPointArray.parray, (void**)&pVar);
for(ULONG u = 0; u < uSelectPointArray; ++u){
strMsg.Format(TEXT("select point %u[%u]"), u, pVar[u]);
AfxMessageBox(strMsg);
}
SafeArrayUnaccessData(vSelectPointArray.parray);
}
if(vSelectPointArray.parray) SafeArrayDestroy(vSelectPointArray.parray);
if(uZPos > 0){
double * pVar;
SafeArrayAccessData(vZPos.parray, (void**)&pVar);
for(ULONG u = 0; u < uZPos; ++u){
strMsg.Format(TEXT("z %u[%lf]"), u, pVar[u]);
AfxMessageBox(strMsg);
}
SafeArrayUnaccessData(vZPos.parray);
}
if(vZPos.parray) SafeArrayDestroy(vZPos.parray);
}
break;
}
lRet = m_MadoriDoc->GetNextObject();
}
// JavaScript sample
var doc = new CMadoriDoc();
var lRet = doc.GetTopObject();
while(lRet){
var uType =doc.GetCurrentObjectType();
alert(uType);
switch (uType){
case 30: // geo feature
var data = eval( doc.GetSiteUpDownJS() );
alert( "Result:[" + data.Result + "]" );
alert( data.Vertex.length );
for( var i=0 ; i < data.Vertex.length ; i++ ){
alert( "Vertex:[" + data.Vertex[i] + "]" );
}
alert( "InputType:[" + data.InputType + "]");
alert( "PolygonHeight:[" + data.PolygonHeight + "]");
alert( "BaseLineIndex:[" + data.BaseLineIndex + "]");
alert( "BaseLineHeight:[" + data.BaseLineHeight + "]");
alert( "Gradient:[" + data.Gradient + "]");
alert( data.SelectPointArray.length );
for( var i=0 ; i < data.SelectPointArray.length ; i++ ){
alert( "SelectPointArray:[" + data.SelectPointArray[i] + "]" );
}
alert( data.ZPos.length );
for( var i=0 ; i < data.ZPos.length ; i++ ){
alert( "ZPos:[" + data.ZPos[i] + "]" );
}
break;
}
lRet = doc.GetNextObject();
}