GetStraightSlope メソッド

構文

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();
}