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