GetRoof メソッド

構文

BOOL GetRoof(VARIANT * vVertex, double * dTangent, double * dHeight, double * dOverhang, unsigned short * bCeiling,
     unsigned short * bHorzCeiling, double * dCeilingDepth, unsigned short * bShrink);

(JavaScript用) string GetRoofJS();

カレントのオブジェクトが、屋根の場合、その情報を取得します。
※PRO7の場合は、Get3DRoof、Set3DRoofをご利用ください。

パラメータ

vVertex
(x, y) 頂点列。型は VT_R8 | VT_ARRAY にしてください。vVertex.parrayは不要になったら、SafeArrayDestroyで解放してください。
dTangent
勾配。
dHeight
軒桁の高さ。
dOverhang
軒の出。
bCeiling
軒天の個別設定をするかどうか。1で個別設定。
bHorzCeiling
水平軒天を付けるかどうか。1で付けます。
dCeilingDepth
水平軒天の奥行き。
bShrink
軒天の先端を縮小するかどうか。1で縮めます。

戻り値

屋根の情報を取得できた場合 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 24: // roof
		{
		VARIANT vVertex;
		vVertex.vt = VT_R8 | VT_ARRAY;
		vVertex.parray = NULL;
		double dTangent, dHeight, dOverhang;
		unsigned short bCeiling, bHorzCeiling;
		double dCeilingDepth;
		unsigned short bShrink;
		m_MadoriDoc->GetRoof(&vVertex, &dTangent, &dHeight, &dOverhang, &bCeiling, 
			&bHorzCeiling, &dCeilingDepth, &bShrink);
		ULONG uVertex = 0;
		if(vVertex.parray){
			uVertex = vVertex.parray->rgsabound[0].cElements;
		}
		strMsg.Format(TEXT("roof tan[%lf]h[%lf]over[%lf]ceiling[%u]horz[%u]depth[%lf]shrink[%u]"), 
			dTangent, dHeight, dOverhang, bCeiling, 
			bHorzCeiling, dCeilingDepth, bShrink);
		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);
	if(uType == 24)
	{
		doc.Select();
		var data = eval( doc.GetRoofJS() );

		alert( "Result[" + data.Result + "]" );

		alert( data.Vertex.length );
		for( var i=0 ; i < data.Vertex.length ; i++ ){
			alert( "Vertex:[" + data.Vertex[i] + "]" );
		}

		var msg = " Tangent[" + data.Tangent + "]\r\n";

		 msg += " Height[" + data.Height + "]\r\n";

		 msg += " Overhang[" + data.Overhang + "]\r\n";

		 msg += " Ceiling[" + data.Ceiling + "]\r\n";

		 msg += " HorzCeiling[" + data.HorzCeiling + "]\r\n";

		 msg += " CeilingDepth[" + data.CeilingDepth + "]\r\n";

		 msg += " Shrink[" + data.Shrink + "]\r\n";

		 msg += " EavesThick Befor[" + doc.GetEavesThick() + "]\r\n";

		doc.SetEavesThick( 200.0 );

		msg += " EavesThick After[" + doc.GetEavesThick() + "]\r\n";

		alert(msg);
		doc.Unselect();
		
	}
	lRet = doc.GetNextObject();
}