GetClippedCeiling メソッド

構文

BOOL GetClippedCeiling(BYTE * byType, unsigned short * bLightOn, VARIANT * vVertex, VARIANT * vHeight,
    VARIANT * vWidth);

カレントのオブジェクトが、折上げ天井の場合、その情報を取得します。

パラメータ

byType
デザイン。次のいずれかの値を指定できます。
  • 1垂直
  • 2垂直飾り縁付
  • 3傾斜
  • 4傾斜飾り縁付
  • 5コーブ照明用
bLightOn
コーブ照明用の場合に、光源をつけるかどうか。0で無し、1でつけます。
vVertex
(x, y) 頂点列。型は VT_R8 | VT_ARRAY にしてください。vVertex.parrayは不要になったら、SafeArrayDestroyで解放してください。
vHeight
高さの配列。要素数は1~3、型は VT_R8 | VT_ARRAY にしてください。要素数が段数になります。vHeight.parrayは不要になったら、SafeArrayDestroyで解放してください。
vWidth
オフセットの配列。要素数は1~3、型は VT_R8 | VT_ARRAY にしてください。要素数が段数になります。vWidth.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("何もない");

while(lRet){
	ULONG uType = m_MadoriDoc->GetCurrentObjectType();
	short nLayer = m_MadoriDoc->GetCurrentObjectLayer();
	CString strMsg;
	strMsg.Format("[%X]type[%d]layer[%d]", lRet, uType,nLayer);
	AfxMessageBox(strMsg);

	switch(uType){
	case 50: // clipped ceiling
		{
		BYTE byType;
		USHORT bLightOn; 
		VARIANT vVertex, vHeight, vWidth;
		vVertex.vt = VT_R8 | VT_ARRAY;
		vVertex.parray = NULL;
		vHeight.vt = VT_R8 | VT_ARRAY;
		vHeight.parray = NULL;
		vWidth.vt = VT_R8 | VT_ARRAY;
		vWidth.parray = NULL;
		m_MadoriDoc->GetClippedCeiling(&byType, &bLightOn, 
			&vVertex, &vHeight, &vWidth);
		ULONG uVertex = 0;
		if(vVertex.parray){
			uVertex = vVertex.parray->rgsabound[0].cElements;
		}
		ULONG uHeight = 0;
		if(vHeight.parray){
			uHeight = vHeight.parray->rgsabound[0].cElements;
		}
		ULONG uWidth = 0;
		if(vWidth.parray){
			uWidth = vWidth.parray->rgsabound[0].cElements;
		}

		strMsg.Format("clipped ceiling type[%d]light[%d]v[%u]h[%u]w[%u]", 
			(int)byType, bLightOn, uVertex, uHeight, uWidth);
		AfxMessageBox(strMsg);
		if(uVertex > 0){
			double * pVar;
			SafeArrayAccessData(vVertex.parray, (void**)&pVar);
			for(ULONG u = 0; u < uVertex; u+=2){
				strMsg.Format("Vertex %u[%lf,%lf]", u/2, pVar[u], pVar[u+1]);
				AfxMessageBox(strMsg);
			}
			SafeArrayUnaccessData(vVertex.parray);
		}
		if(uHeight > 0){
			double * pVar;
			SafeArrayAccessData(vHeight.parray, (void**)&pVar);
			for(ULONG u = 0; u < uHeight; ++u){
				strMsg.Format("Height %u[%lf]", u, pVar[u]);
				AfxMessageBox(strMsg);
			}
			SafeArrayUnaccessData(vHeight.parray);
		}
		if(uWidth > 0){
			double * pVar;
			SafeArrayAccessData(vWidth.parray, (void**)&pVar);
			for(ULONG u = 0; u < uWidth; ++u){
				strMsg.Format("Width %u[%lf]", u, pVar[u]);
				AfxMessageBox(strMsg);
			}
			SafeArrayUnaccessData(vWidth.parray);
		}

		if(vVertex.parray) SafeArrayDestroy(vVertex.parray);
		if(vHeight.parray) SafeArrayDestroy(vHeight.parray);
		if(vWidth.parray) SafeArrayDestroy(vWidth.parray);
		}
		break;
	}
	lRet = m_MadoriDoc->GetNextObject();
}