構文
BOOL GetStraightSlope(VARIANT* vVertex, double* xCenter, double* yCenter, double* xSize, double* ySize,
double* dDegree, double* dHeight1, double* dHeight2, long* bCalcFloorArea);
(JavaScript用) string GetStraightSlopeJS();
カレントのオブジェクトがスロープの場合、その情報を取得します。
パラメータ
vVertex
(x, y) 形状の頂点列。型は VT_R8 | VT_ARRAY にしてください。
xCenter
スロープの中心のX座標。
yCenter
スロープの中心のY座標。
xSize
スロープの幅。
ySize
スロープの奥行き。
dDegree
(上から見た)スロープの角度。
dHeight1
スロープの開始部の高さ。
dHeight2
スロープの終了部の高さ。
bCalcFloorArea
床面積に算入するか。算入するとき1、しないとき0。
戻り値
スロープの情報を取得できた場合 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);
switch(uType){
case 52: // straightslope
{
VARIANT vVertex;
vVertex.vt = VT_R8 | VT_ARRAY;
vVertex.parray = NULL;
double xCenter, yCenter, xSize, ySize, dDegree, dHeight1, dHeight2;
long bCalcFloorArea;
m_MadoriDoc->GetStraightSlope(&vVertex, &xCenter, &yCenter, &xSize, &ySize,
&dDegree, &dHeight1, &dHeight2, &bCalcFloorArea);
ULONG uVertex = 0;
if(vVertex.parray){
uVertex = vVertex.parray->rgsabound[0].cElements;
}
strMsg.Format(TEXT("Slope center[%lf,%lf]size[%lf x %lf]height[%lf -> %lf]"), xCenter, yCenter,
xSize, ySize, dHeight1, dHeight2);
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);
}
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 52: // straightslope
var data = eval( doc.GetStraightSlopeJS() );
var msg = " Result[" + data.Result + "]";
alert(msg);
msg = " Center[" + data.XCenter + ", " + data.YCenter + "]\n" +
" Size[" + data.XSize + " x " + data.YSize + "]\n" +
" Degree[" + data.Degree + "]\n" +
" Height[" + data.Height1 + " -> " + data.Height2 + "]\n" +
" CalcFloorArea[" + data.CalcFloorArea + "]";
alert(msg);
var nPoints = data.Vertex.length / 2;
alert( nPoints );
for( var i=0 ; i < nPoints ; i++ )
{
msg = "Vertex:[" + data.Vertex[i*2] + ", " + data.Vertex[i*2+1] + "]";
alert( msg );
}
break;
}
lRet = doc.GetNextObject();
}