GetSlopedWall3D メソッド

構文

BOOL GetSlopedWall3D(BYTE* byShapeType, BYTE* byCornerType, DOUBLE* dBottom, DOUBLE* dTop, DOUBLE* dSlantDegree,
DOUBLE* dThickness, DOUBLE* dTopDepth, DOUBLE* dMiterLimitDegree,
VARIANT * vVertex, BYTE * byLineStyle, BYTE * byLineWidth, OLE_COLOR * ocLineColor,
     BYTE * byHatchStyle, OLE_COLOR * ocForeColor, OLE_COLOR * ocBackColor, USHORT * bBackTrans);

(JavaScript用) string GetSlopedWall3DJS();

カレントのオブジェクトが、3Dシェイプ(傾斜壁)の場合、その情報を取得します。

パラメータ

byShapeType
形状種類。以下のいずれかの値です。
  • 0板状。
  • 1台状。
byCornerType
入隅の面取り種類。以下のいずれかの値です。
  • 0面取りなし。
  • 1角面取り。
  • 2丸面取り。
dBottom
下端高。
dTop
上端高。
dSlantDegree
傾斜(勾配)角度。
dThickness
「板状」を選んだときの板の厚み。
dTopDepth
上部の平坦部の奥行。
dMiterLimitDegree
「角面取り」を選択したとき、面取りを行う最大角度。
vVertex
(x, y) 頂点列。型は VT_R8 | VT_ARRAY にしてください。
byLineStyle
線種。次のいずれかの値です。
  • 0実線。
  • 1破線。
  • 2点線。
  • 3一点破線。
  • 4二点破線。
  • 5なし。
byLineWidth
線幅。
crLineColor
線色。
byHatchStyle
模様の種類。次のいずれかの値です。
  • 0なし。
  • 1塗りつぶし。
  • 2水平ハッチ。
  • 3垂直ハッチ。
  • 4右下がりハッチ。
  • 5右上がりハッチ。
  • 6水平と垂直の格子ハッチ。
  • 7斜め格子ハッチ。
  • 8ドット1。
  • 9ドット2。
  • 10ドット3。
  • 11ウェーブ1。
  • 12ウェーブ2。
  • 13ウェーブ3。
  • 14斜線1。
  • 15斜線2。
  • 16破線1。
  • 17破線2。
  • 18板目。
  • 19グラデーション横1。
  • 20グラデーション横2。
  • 21グラデーション縦1。
  • 22グラデーション縦2。
  • 23グラデーション右上。
  • 24グラデーション左上。
  • 25グラデーション中心。
  • 26グラデーション右上。
  • 27グラデーション右下。
  • 30半透明。
  • 40水平ハッチ。2の水平ハッチより目が細かい。
  • 41垂直ハッチ。3の垂直ハッチより目が細かい。
  • 42水平と垂直の格子ハッチ。6のハッチより目が細かい。
crForeColor
前景色。
crBackColor
背景色。
bBackTrans
背景を透明にするかどうか。0で不透明、1で透明。

戻り値

3Dシェイプ(傾斜壁)の情報を取得できた場合 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 81: // slopedwall3D
		{
		VARIANT vVertex;
		vVertex.vt = VT_R8 | VT_ARRAY;
		vVertex.parray = NULL;

		BYTE byShapeType, byCornerType;
		double dBottom, dTop, dSlantDegree, dThickness, dTopDepth, dMiterLimitDegree;
		unsigned char byLineStyle, byLineWidth;
		unsigned long ocLineColor;
		unsigned char byHatchStyle;
		unsigned long ocForeColor, ocBackColor;
		unsigned short bBackTrans;
		m_MadoriDoc->GetSlopedWall3D(&byShapeType, &byCornerType, &dBottom, &dTop, &dSlantDegree, &dThickness, &dTopDepth, &dMiterLimitDegree,
			&vVertex, &byLineStyle, &byLineWidth, &ocLineColor, 
			&byHatchStyle, &ocForeColor, &ocBackColor, &bBackTrans);
		ULONG uVertex = 0;
		if(vVertex.parray){
			uVertex = vVertex.parray->rgsabound[0].cElements;
		}
		strMsg.Format(TEXT("SlopedWall3D vertex[%d]lineStyle[%d]width[%d]col[%x]")
			TEXT("hatch[%d]for[%x]back[%x]trans[%d]"),
			uVertex, byLineStyle, byLineWidth, ocLineColor,
			byHatchStyle, ocForeColor, ocBackColor, bBackTrans);
		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 81: // slopedwall3D

		var data = eval( doc.GetSlopedWall3DJS() );

		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 = " LineStyle[" + data.LineStyle + "]";
		alert(msg);

		var msg = " LineWidth[" + data.LineWidth + "]";
		alert(msg);

		var msg = " LineColor[" + data.LineColor + "]";
		alert(msg);

		var msg = " HatchStyle[" + data.HatchStyle + "]";
		alert(msg);

		var msg = " ForeColor[" + data.ForeColor + "]";
		alert(msg);

		var msg = " BackColor[" + data.BackColor + "]";
		alert(msg);

		var msg = " BackTrans[" + data.BackTrans + "]";
		alert(msg);

		break;
	}

	lRet = doc.GetNextObject();
}