GetDormer2 メソッド

構文

BOOL GetDormer2(VARIANT * pvVertex,
     long* nStyle, double* dWidth, double* dHeight, double* dTangent, double* dEavesOut,
     double* dEavesThick, double* dAngle, double* xCenter, double* yCenter);

(JavaScript用) string GetDormer2JS();

カレントのオブジェクトがドーマーの場合、その情報を取得します。

パラメータ

pvVertex
(x, y) 頂点列。型は VT_R8 | VT_ARRAY にしてください。vVertex.parrayは不要になったら、SafeArrayDestroyで解放してください。
nStyle
ドーマーの屋根のスタイル。以下のいずれかの値です。
  • 0片流れ
  • 1切妻
  • 2寄棟
dWidth
ドーマーの幅。
dHeight
ドーマーの高さ。
dTangent
ドーマーの屋根の勾配。
dEavesOut
軒の出。
dEavesThick
軒天の厚さ。
dAngle
(上から見た)角度。
xCenter
ドーマーの中心のX座標。
yCenter
ドーマーの中心のY座標。

戻り値

ドーマーの情報を取得できた場合 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 61: // dormer
		{                        
		VARIANT vVertex;
		vVertex.vt = VT_R8 | VT_ARRAY;
		vVertex.parray = NULL;
		double dWidth, dHeight, dTangent, dEavesOut, dEavesThick, dAngle, xCenter, yCenter;
		long nStyle;

		m_MadoriDoc->GetDormer2(&vVertex, &nStyle, &dWidth, &dHeight, &dTangent, &dEavesOut,
     		&dEavesThick, &dAngle, &xCenter, &yCenter);
		strMsg.Format(TEXT("Dormer style[%d]width[%d]height[%lf]tangent[%lf]"), nStyle, dWidth,
			dHeight, dTangent);
		AfxMessageBox(strMsg);                        
		strMsg.Format(_T("Dormer Style[%ld]Width[%lf]Height[%lf]")
			_T("Tangent[%lf]EavesOut[%lf]EavesThick[%lf]Angle[%lf]")
			_T("XCenter[%lf]YCenter[%lf]"),
			nStyle, dWidth, dHeight, dTangent, dEavesOut, dEavesThick, dAngle,
			xCenter, yCenter);
		AfxMessageBox(strMsg);
		ULONG uVertex = 0;
		if (vVertex.parray) {
			uVertex = vVertex.parray->rgsabound[0].cElements;
		}
		if (uVertex > 0) {
			double * pVar;
			SafeArrayAccessData(vVertex.parray, (void**)&pVar);
			for (ULONG u = 0; u < uVertex; u += 2) {
				strMsg.Format(_T("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 61: // dormer
		var data = eval( doc.GetDormer2JS() );

		var msg = " Result[" + data.Result + "]";
		alert(msg);    
        alert(data.Vertex.length);
        for (var i = 0 ; i < data.Vertex.length ; i++) {
            alert("Vertex:[" + data.Vertex[i] + "]");
        }
    
        var msg = " Style[" + data.Style + "]\r\n";
        msg += " Width[" + data.Width + "]\r\n";
        msg += " Height[" + data.Height + "]\r\n";
        msg += " Tangent[" + data.Tangent + "]\r\n";
        msg += " EavesOut[" + data.EavesOut + "]\r\n";
        msg += " EavesThick[" + data.Style + "]\r\n";
        msg += " Angle[" + data.Angle + "]\r\n";
        msg += " XCenter[" + data.XCenter + "]\r\n";
        msg += " YCenter[" + data.YCenter + "]\r\n";
		alert(msg);

		break;
	}

	lRet = doc.GetNextObject();
}