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