Skip to content
On this page

[mxcad_2d API documentation] (../README. md)/[2d] (../modules/2d. md)/McObject

Class: McObject

2d.McObject

The McObject class encapsulates the functionality related to MxCAD objects and provides methods to manipulate and manage these functionalities

Table of contents

Constructors

Accessors

Methods

Constructors

constructor

new McObject(imp?)

Constructor function

Parameters

NameTypeDescription
imp?AnyObject Implementation

Example

ts
import { McObject } from 'mxcad'

const mxcad = new McObject;

Accessors

database

get database(): McDbDatabase

Return database object

Returns

McDbDatabase


drawColor

get drawColor(): McCmColor

Get drawing colors

Returns

McCmColor

Return to drawing color

set drawColor(val): void

Set drawing color

Parameters

NameTypeDescription
Val[McCMColor] (2d. McCmColor. md)Draw colors

Returns

void

Example

ts
import { MxCpp, McObject } from 'mxcad';
const mxcad:McObject = MxCpp.App.getCurrentMxCAD();
mxcad.drawColor = new McCmColor(0, 0, 255);

drawColorIndex

get drawColorIndex(): number

Set color index for drawing

Returns

number

Val color index type

set drawColorIndex(val): void

Set color index for drawing

Parameters

NameTypeDescription
Valnumbercolor index type

Returns

void

Example

ts
import { MxCpp, ColorIndexType, McObject } from "mxcad" ;
const mxcad:McObject = MxCpp.App.getCurrentMxCAD();
mxcad.drawColorIndex = ColorIndexType.kMagenta;

drawDimStyle

get drawDimStyle(): string

Get the currently drawn annotation style

Returns

string

set drawDimStyle(val): void

Set the annotation style for the current drawing

Parameters

NameTypeDescription
ValstringStyle Name

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawDimStyle = "MyDimStyle2"

drawLayer

get drawLayer(): string

Get drawing layers

Returns

string

Return to drawing layer

set drawLayer(val): void

Set drawing layer

Parameters

NameTypeDescription
ValstringDraw layers

Returns

void

Example

ts
import { MxCpp, McObject } from 'mxcad'
  const mxcad:McObject = MxCpp.getCurrentMxCAD();
   mxcad.drawLayer = "MtextLayer";

drawLineTypeScale

get drawLineTypeScale(): number

Obtain the scale of the drawn line type

Returns

number

Return to drawing line type scale

set drawLineTypeScale(val): void

Set the drawing line scale

Parameters

NameTypeDescription
ValnumberDraw line type scale

Returns

void


drawLineWeight

get drawLineWeight(): LineWeight

Get drawing line width

Returns

LineWeight

Return to drawing line width

set drawLineWeight(val): void

Set drawing line width

Parameters

NameTypeDescription
Val[LineWeight] (../enums/2d. McDb. LineWeight. md)Draw line width

Returns

void

Example

ts
import { MxCpp, McDb, McObject } from "mxcad" ;

const mxcad: McObject = MxCpp.App.getCurrentMxCAD();
mxcad.drawLineWeight(McDb.LineWeight.kLnWtByLayer)

drawLineWidth

get drawLineWidth(): number

Get the current drawn line width

Returns

number

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad: McObject = MxCpp.getCurrentMxCAD()
mxcad.drawLineWidth = 4;

set drawLineWidth(val): void

Set the current drawn line width

Parameters

NameTypeDescription
Valnumberline width

Returns

void


drawLinetype

get drawLinetype(): string

Obtain the drawing line type

Returns

string

Return to drawing line type

set drawLinetype(val): void

Set drawing line type

Parameters

NameTypeDescription
ValstringDraw line types

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad" ;

const mxcad: McObject = MxCpp.App.getCurrentMxCAD();
mxcad.addLinetype("MyLineType3", "30,-10");
mxcad.drawLinetype = "MyLineType3";

drawPatternDefinition

get drawPatternDefinition(): string

Get the current line type definition drawn

Returns

string

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad: McObject = MxCpp.getCurrentMxCAD()
mxcad.drawPatternDefinition = "MyHatchPattern1";

set drawPatternDefinition(val): void

Set the line type definition for the current drawing

Parameters

NameTypeDescription
ValstringLine type definition

Returns

void


drawTextStyle

get drawTextStyle(): string

Get the style of drawing text

Returns

string

Return to drawing text style

set drawTextStyle(val): void

Set the style for drawing text

Parameters

NameTypeDescription
ValstringDraw text styles

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad" ;

const mxcad: McObject = MxCpp.App.getCurrentMxCAD();
mxcad.addTextStyle("MyTextStyle", "italicc.shx", "gbcbig.shx", 0.7);
mxcad.drawTextStyle = "MyTextStyle";

drawUseDefaultProperties

get drawUseDefaultProperties(): boolean

Return the number of drawings starting with the call 'draw', using the current default properties of the database.

Returns

boolean

set drawUseDefaultProperties(val): void

Set the number of drawings starting with 'draw' when calling, using the current default properties of the database

Parameters

NameTypeDescription
ValbooleanLine width

Returns

void


mxdraw

get mxdraw(): MxDrawObject

Return the MxDraw object bound to the MxCAD object.

Returns

MxDrawObject

MxDraw object

Example

ts
import { McObject } from 'mxcad'

const mxcad = new McObject()
const mxdraw = mxcad.mxdraw

Methods

AddTureTypeTextStyle

AddTureTypeTextStyle(sName, sTrueTypeFontName?, dXScale?): McObjectId

Add text styles using TrueType fonts

Parameters

NameTypeDefault valueDescription
sNamestringundefined-
STrueTypeFontNamestring""TrueType font name, if left blank, use the default TrueType font
DXScalenumber1.0X-direction scaling ratio

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.AddTureTypeTextStyle("MyTrueTypeTextStyle");

addCurrentSelect

addCurrentSelect(id, isDisplayGrid?): void

Add the object to the current selection

Parameters

NameTypeDefault valueDescription
Id[McObjectid] (2d. McObjectid. md) \[McObjectid] (2d. McObjectid. md) []undefined
isDisplayGridbooleantrue-

Returns

void

void

Example

typescript
import { MxCpp, McObject } from "mxcad"
let mxcad:McObject = MxCpp.getCurrentMxCAD();
let id = mxcad.drawLine(0,0,1000,1000);
mxcad.addCurrentSelect(id);

addDimStyle

addDimStyle(pszName, pszDoubleData, pszIntData, pszStringData, pszIdData): McObjectId

Add annotation style

Parameters

NameTypeDescription
PszNamestringStyle Name
PszDoubleDatastringDouble precision data
PszIntDatastringinteger data
pszStringDatastringString data
PszIdDatastringID type data

Returns

McObjectId

Description

PszDoubleData Double Precision Data

System VariablesValuesFunction Description
Dimaltf143Control the multiplier for converting units
Dimasz41Control the size of dimension lines and lead arrows. And control the size of the baseline
Dimcen141Control the marking of circle or arc centers and the drawing of centerlines
Dimdle46When using a small diagonal line instead of an arrow for annotation, set the distance from the dimension line beyond the dimension boundary line
Dimdli43Control the spacing of dimension lines in baseline annotation
Dimexe44Export named annotation styles and their settings to an external file
Dimexo42Specify the distance from the origin of the dimension extension line
Dimgap147Set the distance around the annotation text when the dimension line is broken to conform to the annotation text
Dimlfac144Set the scaling factor for linear annotation measurement values
Dimrnd45Rounds all annotated distances to the specified value
Dimscale40Set the global scale factor applied to the annotation variable (used to specify size, distance, or offset)
Dimtfac146As set through the DIMTXT system variable, specify the scaling factor of the text height of the score and tolerance values relative to the annotation text height
Dimtm48Set the minimum (i.e. lowest) tolerance limit for the annotation text
Dimtp47Set the maximum (i.e. highest) tolerance limit for the annotation text
Dimtsz142Specify the size of the small diagonal lines drawn instead of arrows in linear, radius, and diameter annotations
Dimtvp145Control the vertical position of the annotation text above or below the dimension line
Dimtxt140Specify the height of the annotation text (unless the current text style has a fixed height)
Dimaltrnd148Rounding conversion annotation unit

Description

PszIntData integer data

System VariablesValuesFunction Description
Dimadec179Control the precision decimal places displayed in the angle annotation
Dimalt170Controls the display of conversion units in annotations
Dimaltd171Control the number of decimal places in the conversion unit
Dimalttd274Set the decimal place for the tolerance value in the conversion annotation unit
Dimalttz286Control the zeroing process of tolerance values
Dimaltu273Set the unit format for the conversion units of all annotation sub styles (excluding angular annotations)
Dimaltz285Control the zeroing process for the annotation values of conversion units
Dimaunit275Set the unit format for angle annotation
Dimclrd176Specify colors for dimension lines, arrows, and dimension leaders
Dimctre177Specify colors for dimension lines, center marks, and centerlines
Dimclrt178Specify the color for the annotation text
Dimdec271Set the number of decimal places displayed in the primary unit of the annotation
When the space within the dimension line is insufficient to accommodate both the annotation text and the arrow, this system variable will determine the arrangement of both
Dimjust280Control the horizontal position of the annotation text
Dimlim72Generate annotation boundaries as default text
Dimsah173Control the display of dimension line arrow blocks
Dimsd1281Control whether to hide the first dimension line and arrow
Dimsd2282Control whether to hide the second dimension line and arrow
Dimse175Control whether to hide the first dimension line
Dimse276Control whether to hide the second dimension line
Dimsoxd175If there is not enough space within the dimension line, hide the arrow
Dimtad77Control the vertical position of the text relative to the dimension line
Dimtdec272Set the number of decimal places displayed in the tolerance value of the primary unit of the annotation
Dimtih73Controls the position of annotation text for all annotation types (excluding coordinate annotations) within the dimension lines
Dimtix174Draw text between dimension lines
Dimtofl172Controls whether dimension lines are drawn between dimension lines (even if the dimension text is placed outside the dimension lines)
Dimitoh74Control the position of the annotation text outside the dimension line
Ditol71Attach the tolerance in the annotation text
Dimtolj283Set the vertical alignment of tolerance values relative to surface annotation text
Dimzin78Control the zeroing process for the main unit value
Dimupt288Control the option for users to locate text
Dimtzin284Control the zeroing process of tolerance values
Dimfrac276Set score format
Dimlunit277Set units for all annotation types (excluding angular annotations)
When the space within the dimension line is insufficient to accommodate both the annotation text and the arrow, this system variable will determine the arrangement of both
Dimtmove279Set the movement rules for annotation text
Dimazin79Zero elimination processing for angle annotation

Description

PszStringData string type data

System VariablesValuesFunction Description
Dimapost4Specify the text prefix or suffix (or both) used for converting dimension measurements for all dimension types (excluding angular dimensions)
Dimpost3Specify a text prefix or suffix (or both) for annotating measurement values

Description

PszIdData ID type data

System VariablesValuesFunction Description
Dimblk342Set an arrow for the second endpoint of the dimension line
Dimblk1343Set an arrow for the first endpoint of the dimension line
Dimblk2344Set an arrow for the second endpoint of the dimension line
Dimldrblk341Specify the type of leader arrow
Dimtxsty340Specify the text style for the annotation

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD();

//MyDimStyle2: Style Name
//41, 0.18141, 0.09, 40200 ": Double precision data
//77,1271,3 ": integer data
//Among them, the values are set in pairs, such as "41,0.18": the value of the dimasz system variable is set to 0.18; 77,1 ": The value of the dimtad system variable is set to 1
mxcad.addDimStyle("MyDimStyle2", "41,0.18,141,0.09,40,200", "77,1,271,3", "", "");
Add a%% c prefix '3, "%%c<>"'
mxcad.addDimStyle("MyDimStyle", "41,0.18,141,0.09,40,200", "77,1,271,3", '3,"%%c<>"', `340,${textId.id}`);

addImageDefine

addImageDefine(imageUrl, sName?, isConvertBase64?): McObjectId

Add an image definition to the CAD database.

Parameters

NameTypeDefault valueDescription
ImageURLstringundefinedImage path
SNamestring""Image Definition Name
isConvertBase64booleanfalse-

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
   let mxcad:McObject = MxCpp.getCurrentMxCAD();
   let imagUrl = "https://cdn.pixabay.com/photo/2022/11/15/12/23/winter-7593872_960_720.jpg";
   mxcad.loadImage(imagUrl, (imagedata) => {
       if (!imagedata) {
           console.log("loadImage failed");
           return;
       }
       let imagedefid = mxcad.addImageDefine(imagUrl,"winter-7593872_960_720.jpg",true);
       mxcad.updateDisplay();
   });

addLayer

addLayer(string): McObjectId

Add Layer

Parameters

NameType
stringstring

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
Mxcad. addLayer ("Layer Name")

addLinetype

addLinetype(sName, sLineDefine): McObjectId

Add line type

Parameters

NameType
sNamestring
sLineDefinestring

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
//Define dashed data, "MyLineType" is the line name, "6, -8" is a unit definition of the dashed line, 6 is the length of the solid line, and -8 is the length of the space.
mxcad.addLinetype("MyLineType", "6,-10");

addLinetypeEx

addLinetypeEx(sName, sLineDefine, sTextStyle?): McObjectId

Add line type

Parameters

NameTypeDefault value
sNamestringundefined
sLineDefinestringundefined
sTextStylestring""

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
let lintype = mxcad.addLinetypeEx("TestMyLine", '.5,-.2,["HW",STANDARD,S=.1,R=0.0,X=-0.1,Y=-.05],-.2', "");

addPatternDefinition

addPatternDefinition(sName, sDefinitionData): void

Add a pattern definition

Parameters

NameTypeDescription
SNamestringPattern Name
SDefinitionDatastringPattern default definition data

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"
   const mxcad:McObject = MxCpp.getCurrentMxCAD()
   //angle, x-origin,y-origin, delta-x,delta-y,dash-1,dash-2, …
//45=angle is the angle of the pattern line
//0=x-origin is the X-coordinate of the point where the first fill line passes through
//0=y-origin is the Y coordinate of the point where the first fill line passes through
//0=delta-x is the X-direction offset of the next fill line relative to the previous line
//0.125=delta-y is the Y-direction offset of the next fill line relative to the previous line
   mxcad.addPatternDefinition("MyHatchPattern1", "((45, 0,0, 0,0.125))");

addSystemVarNameForEvent

addSystemVarNameForEvent(aryVarName): void

Add a system variable name for event notification after variable object modification Variable object modification event name: sysVarChanged

Parameters

NameType
aryVarNamestring[]

Returns

void


addTextStyle

addTextStyle(sName, sFileName, sBigFontFileName, dXScale?): McObjectId

Add Text Style

Parameters

NameTypeDefault valueDescription
sNamestringundefined-
sFileNamestringundefined-
sBigFontFileNamestringundefined-
DXScalenumber1.0X-direction scaling ratio

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD() 
mxcad.addTextStyle("MyLineTypeTextStyle", "txt.shx", "hztxt.shx", 1);

callEvent

callEvent(sEventName, param?): boolean

Call to trigger a system event

Parameters

NameTypeDescription
sEventNamestring-
param?` AnyEvent Parameters

Returns

boolean

Example

ts
import { MxCpp, McObject } from "mxcad"

const mxcad:McObject = MxCpp.getCurrentMxCAD();
mxcad.callEvent("init");

clearDwgBackground

clearDwgBackground(): void

Clear background drawing objects

Returns

void


clearMxCurrentSelect

clearMxCurrentSelect(): void

Clear all current selections

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"

const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.clearCurrentSelect();

create

create(config): void

Create an MXCAD object.

Parameters

NameTypeDescription
config[MxCadConfig] (../interfaces/2d. MxCadConfig. md)Parameter configuration for creating MxCad

Returns

void

Example

ts
import { McObject } from "mxcad"

//Create an MXCAD sample object
 const mxcad = new McObject()
mxcad.create({
//The ID of the canvas element
canvas: "#myCanvas",
//Retrieve the path location for loading wasm related files (wasm/js/worker. js)
locateFile: (fileName)=> new URL(`/node_modules/mxcad/dist/wasm/2d/${fileName}`, import.meta.url).href,
//Need to initialize the URL path of the opened file
fileUrl: new URL("../src/assets/test.mxweb", import.meta.url).href,
//Provide the directory path for loading fonts
fontspath:  new URL("node_modules/mxcad/dist/fonts", import.meta.url).href,
})

destroyObject

destroyObject(pObjectImp): void

Destroy the specified McRxObject Imp object

Parameters

NameTypeDescription
PObject ImpMcRx Object ImpMcRx Object Imp object to be destroyed

Returns

void


drawArc

drawArc(dCenterX, dCenterY, dRadius, dStartAng, dEndAng): McObjectId

Draw an arc

Parameters

NameTypeDescription
DCenterXnumberX coordinate of the center of the circle
DCenterYnumberY coordinate of the center
DRadiusnumberradius
DStartAngnumberStarting angle, in radians
DEndAngnumberEnd angle, in radians

Returns

McObjectId

Success returns 1, failure returns 0

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad: McObject = MxCpp.getCurrentMxCAD()
mxcad.drawArc(300, 1000, 100, 30, 200);

drawArc2

drawArc2(dStartPointX, dStartPointY, dMidPointX, dMidPointY, dEndPointX, dEndPointY): McObjectId

Draw an arc

Parameters

NameTypeDescription
DStartPointXnumberstarting point X coordinate
DStartPointYnumberStarting point Y coordinate
DMidPointXnumberX coordinate of the midpoint
DMidPointYnumberY coordinate of the midpoint
DEndPointXnumberEnd point X coordinate
DEndPointYnumberEnd point Y coordinate

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
//Draw an arc from three points on the arc
mxcad.drawArc2(800, 1000, 900, 1200, 1000, 900);

drawArc3

drawArc3(dStartPointX, dStartPointY, dEndPointX, dEndPointY, dBulge): McObjectId

Draw an arc

Parameters

NameTypeDescription
DStartPointXnumberstarting point X coordinate
DStartPointYnumberStarting point Y coordinate
DEndPointXnumberEnd point X coordinate
DEndPointYnumberEnd point Y coordinate
DBulgenumberconvexity

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
  const mxcad:McObject = MxCpp.getCurrentMxCAD()
//The starting point, ending degree, and convexity on the arc will form an arc
  mxcad.drawLineWidth = 40;
  mxcad.drawArc3(1200, 1000, 1400, 1000, 0.6);

drawBlockReference

drawBlockReference(dPosX, dPosY, sBlkName, dScale, dAng): McObjectId

Draw block reference

Parameters

NameTypeDescription
DPosXnumberReference position X coordinate
DPosYnumberReference position Y coordinate
sBlkNamestring-
DScalenumberscaling ratio
DAngnumberRotation angle, in radians

Returns

McObjectId

Block object ID


drawCircle

drawCircle(dCenterX, dCenterY, dRadius): McObjectId

Draw a circle

Parameters

NameTypeDescription
DCenterXnumberX coordinate of the center of the circle
DCenterYnumberY coordinate of the center
DRadiusnumberradius

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD(
mxcad.drawCircle(0, 0, 120);

drawDimAligned

drawDimAligned(dExtLine1PointX, dExtLine1PointY, dExtLine2PointX, dExtLine2PointY, dTextPositionX, dTextPositionY): McObjectId

Draw alignment annotations

Parameters

NameTypeDescription
DExtLine1PointXnumberX-coordinate of the starting point of the first ruler line
DExtLine1PointYnumberY coordinate of the starting point of the first ruler line
DExtLine2PointXnumberX-coordinate of the starting point of the second ruler line
DExtLine2PointYnumberY coordinate of the starting point of the second ruler line
DTextPositionXnumberText Position X Coordinate
DTextPositionYnumberY coordinate of text position

Returns

McObjectId

Success returns 1, failure returns 0

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawDimAligned(0, 4000, 300, 4500, 150, 4600);

drawDimAngular

drawDimAngular(dAngleVertexX, dAngleVertexY, dFirstEndPointX, dFirstEndPointY, dSecondEndPointX, dSecondEndPointY, dTextPointX, dTextPointY): McObjectId

Draw angle annotation

Parameters

NameTypeDescription
DAngle VertexXnumberangle vertex X coordinate
DAngle VertexYnumberY-coordinate of angle vertex
DFirstEndPointXnumberX-coordinate of the starting point of the first ruler line
DFirstEndPointYnumberY coordinate of the starting point of the first ruler line
DSecondEndPointXnumberX coordinate of the starting point of the second ruler line
DSecondEndPointYnumberY coordinate of the starting point of the second ruler line
DTextPointXnumberText Position X Coordinate
DTextPointYnumberText Position Y Coordinate

Returns

McObjectId

Success returns 1, failure returns 0

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawDimAngular(500, 5000, 0, 5500, 1000, 5500, 500, 5500);

drawDimDiametric

drawDimDiametric(dChordPointX, dChordPointY, dFarChordPointX, dFarChordPointY, dLeaderLength): McObjectId

Draw diameter annotation

Parameters

NameTypeDescription
DChordPointXnumberChord endpoint X coordinate
DChordPointYnumberchord endpoint Y coordinate
DFarChordPointXnumberX coordinate of the far end point of the string
DFarChordPointYnumberY-coordinate of the far end point of the string
DLeaderLengthnumberlead length

Returns

McObjectId

Diameter annotation object ID

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawDimDiametric(500, 0, -500, 0, 20);

drawDimOrdinate

drawDimOrdinate(dDefinitionPointX, dDefinitionPointY, dDeaderEndPointX, dDeaderEndPointY, isUseXAxis): McObjectId

Draw linear dimensions for annotation

Parameters

NameTypeDescription
DDefinitionPointXnumberDefine the coordinates of point X
DDefinitionPointYnumberDefine the coordinates of point Y
DDeaderEndPointXnumberAnnotate the X coordinate of the endpoint
DDeaderEndPointYnumberAnnotate the Y coordinate of the endpoint
Is' isUseXAxis''boolean'labeled along the X-axis direction

Returns

McObjectId

Linear size object ID

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawDimOrdinate(500, 0, -500, 0, true);

drawDimRadial

drawDimRadial(dCenterX, dCenterY, dChordPointX, dChordPointY, dLeaderLength): McObjectId

Draw radial dimensions for annotation

Parameters

NameTypeDescription
DCenterXnumberX coordinate of the center point
DCenterYnumberY coordinate of the center point
DChordPointXnumberChord endpoint X coordinate
DChordPointYnumberchord endpoint Y coordinate
DLeaderLengthnumberLength of annotation line

Returns

McObjectId

Radial dimension object ID

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawDimOrdinate(0, 0, 0, 500, 20);

drawDimRotated

drawDimRotated(dExtLine1PointX, dExtLine1PointY, dExtLine2PointX, dExtLine2PointY, dDimLineLocationX, dDimLineLocationY, dRotationAngle): McObjectId

Draw rotation annotation

Parameters

NameTypeDescription
DExtLine1PointXnumberX-coordinate of the starting point of the first ruler line
DExtLine1PointYnumberY coordinate of the starting point of the first ruler line
DExtLine2PointXnumberX-coordinate of the starting point of the second ruler line
DExtLine2PointYnumberY coordinate of the starting point of the second ruler line
DDimLinePositionXnumberannotation line position X coordinate
DDimLinePositionYnumberY coordinate of annotation line position
DRotationAnglenumberRotation angle, in radians

Returns

McObjectId

Rotate annotation object ID

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD() 
mxcad.drawDimRotated(0, 7000, 600, 7000, 250, 7050, 0);

drawEllipse

drawEllipse(dCenterX, dCenterY, dMajorAxisX, dMajorAxisY, dRadiusRatio): McObjectId

Draw an ellipse

Parameters

NameTypeDescription
DCenterXnumberX-coordinate of ellipse center
DCenterYnumberY coordinate of ellipse center
DMajorAxisXnumberlong axis X coordinate
DMajorAxisYnumberLong axis Y coordinate
DRadiusRationumberratio of minor axis to major axis

Returns

McObjectId

Success returns 1, failure returns 0

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawEllipse(0, 1400, 100, 0, 0.7);

drawEllipseArc

drawEllipseArc(dCenterX, dCenterY, dMajorAxisX, dMajorAxisY, dRadiusRatio, dStartAng, dEndAng): McObjectId

Draw an elliptical arc

Parameters

NameTypeDescription
DCenterXnumberX-coordinate of ellipse center
DCenterYnumberY coordinate of ellipse center
DMajorAxisXnumberlong axis X coordinate
DMajorAxisYnumberLong axis Y coordinate
DRadiusRationumberratio of minor axis to major axis
DStartAngnumberStarting angle, in radians
DEndAngnumberEnd angle, in radians

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawEllipseArc(0, 1600, 80, 30, 0.4, 30, 200);

drawEntity

drawEntity(entity, isUseDatabaseCurrentProperties?): McObjectId

Draw entities

Parameters

NameTypeDefault valueDescription
Entity[McDbEntity] (2d. McDbEntity. md)undefinedEntity object
isUseDatabaseCurrentPropertiesbooleanfalse-

Returns

McObjectId

Draw Results

Example

ts
import { McDbPolyline, MxCpp } from
let pl = new McDbPolyline();
  pl.addVertexAt(new McGePoint3d(100, 100, 100));
  pl.addVertexAt(new McGePoint3d(200, 100, 500));
  pl.addVertexAt(new McGePoint3d(300, 400, 200));
  MxCpp.getCurrentCAD().drawEntity(pl);

drawHatch

drawHatch(hatch, dPatternScale?): McObjectId

Draw Fill Object

Parameters

NameTypeDefault value
hatchMcDbHatchundefined
dPatternScalenumber1.0

Returns

McObjectId

Draw object ID


drawImage

drawImage(dPosX, dPosY, dWidth, dHeight, dAng, imageUrl, isConvertBase64?, dwgImageSizeWidth?, dwgImageSizeHeight?): McObjectId

Draw an image

Parameters

NameTypeDefault valueDescription
DPosXnumberundefinedX coordinate of image
DPosYnumberundefinedY coordinate of image
DWidthnumberundefinedimage width
DHeightnumberundefinedImage height
DAngnumberundefinedImage angle, in degrees
ImageURLstringundefinedImage path
isConvertBase64booleanfalse-
dwgImageSizeWidthnumber1.0-
dwgImageSizeHeightnumber1.0-

Returns

McObjectId


drawLine

drawLine(dX1, dY1, dX2, dY2): McObjectId

draw a straight line

Parameters

NameTypeDescription
DX1numberStarting point X coordinate
DY1numberStarting point Y coordinate
DX2numberendpoint X coordinate
DY2numberEnd point Y coordinate

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawLine(0, 60, 100, 60);

drawLine3d

drawLine3d(dX1, dY1, dZ1, dX2, dY2, dZ2): McObjectId

Parameters

NameType
dX1number
dY1number
dZ1number
dX2number
dY2number
dZ2number

Returns

McObjectId


drawMText

drawMText(dPosX, dPosY, sContents, dHeight, dWidth, dRotation, iAttachment): McObjectId

Draw multiple lines of text

Parameters

NameTypeDescription
DPosXnumberText Position X Coordinate
DPosYnumberY coordinate of text position
sContentsstring-
DHeightnumberText height
DWidthnumberText width
DRotationnumberRotation angle, in radians
IAttachment[AttachmentPoint] (../enums/2d. McDb. AttachmentPoint. md)Alignment Method

Returns

McObjectId

Multi line text object ID

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
Mxcad.drawMText (0, -100, "Control:\ \P Multi line Text Test ", 50, 400, 0, 1);

drawPathToHatch

drawPathToHatch(dPatternScale?): McObjectId

Convert the path to a fill pattern

Parameters

NameTypeDefault valueDescription
DPatternScalenumber1.0Pattern scaling ratio

Returns

McObjectId

Conversion results

Example

ts
import { MxCADUiPrPoint, MxCADUiPrDist, MxCpp } from "mxcad";
//Solid circle
   async function Mx_SolidCircle() {
       const getCenter = new MxCADUiPrPoint();
GetCenter.setMessage ('Please confirm the center position ');
       const center = await getCenter.go();
       if (!center) return;
       const getRadius = new MxCADUiPrDist();
getRadius.setBasePt(center);//  Set the distance base point as the center of the circle
GetRadius.setMessage ('Please enter circle radius');
       getRadius.setUserDraw((pt, pw) => {
           const r = pt.distanceTo(center);
           const circle = new McDbCircle();
           circle.center = center;
           circle.radius = r;
           pw.drawMcDbEntity(circle)
       })
       const radiusVal = await getRadius.go();
       if (!radiusVal) return;
       const radius = getRadius.value();
       const mxcad = MxCpp.getCurrentMxCAD();
mxcad.pathCircle(center.x, center.y, radius);// Set circular path
mxcad.drawPathToHatch();//  Draw a solid circle
   }

drawPathToPolyline

drawPathToPolyline(): McObjectId

Convert the path to a polyline

Returns

McObjectId

Conversion results


drawPathToSpline

drawPathToSpline(): McObjectId

Convert the path to a spline curve

Returns

McObjectId

Conversion results


drawPoint

drawPoint(dX, dY): McObjectId

Draw points

Parameters

NameTypeDescription
DXnumberX coordinate
DYnumberY coordinate

Returns

McObjectId

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.drawPoint(0,0);

drawSolid

drawSolid(dX1, dY1, dX2, dY2, dX3, dY3, dX4, dY4): McObjectId

Draw entities

Parameters

NameTypeDescription
DX1numberX coordinate of the first point
DY1numberY coordinate of the first point
DX2numberX coordinate of the second point
DY2numberY coordinate of the second point
DX3numberX coordinate of the third point
DY3numberY coordinate of the third point
DX4numberX coordinate of the fourth point
DY4numberY coordinate of the fourth point

Returns

McObjectId

Entity Object ID


drawText

drawText(dPosX, dPosY, pszText, dHeight, dRotation, horizontalMode, verticalMode): McObjectId

Draw a single line of text

Parameters

NameTypeDescription
DPosXnumberText Position X Coordinate
DPosYnumberY coordinate of text position
PszTextstringText Content
DHeightnumberText height
DRotationnumberRotation angle, in radians
HorizontalMode[TextHorzMode] (../enums/2d. McDb. TextHorzMode. md)Horizontal alignment method
Vertical Mode[TextVertMode] (../enums/2d. McDb. TextVertMode. md)Vertical Alignment Method

Returns

McObjectId

Success returns 1, failure returns 0

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
Mxcad.drawText (0, 1900, "Drawing Control Text Test", 100, 0, 0, 1);

getAllLayoutName

getAllLayoutName(): McGeStringArray

Get all layout names

Returns

McGeStringArray


getBackgroundEntity

getBackgroundEntity(): McDbBackgroundEntity

Return the current background object

Returns

McDbBackgroundEntity


getCurrentDatabaseDrawColor

getCurrentDatabaseDrawColor(): Color

Returns the drawing color set in the current database, which will automatically convert black and white based on the background color.

Returns

Color


getCurrentFileName

getCurrentFileName(): string

Get the current file name

Returns

string

Current file name


getCurrentOriginaFileName

getCurrentOriginaFileName(): string

Get the current file name

Returns

string

Current file name


getDatabase

getDatabase(): McDbDatabase

Retrieve database objects

Returns

McDbDatabase

Database objects

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.App.getCurrentMxCAD()
let layerTable = mxcad.getDatabase().getLayerTable();

getImp

getImp(): any

Retrieve internal implementation objects

Returns

any

Internal implementation object


getMxCpp

getMxCpp(): any

Add back the MxCpp object, which will be called in the MxDraw module.

Returns

any


getMxDrawObject

getMxDrawObject(): MxDrawObject

Return the MxDraw object bound to the MxCAD object.

Returns

MxDrawObject

MxDraw object

Example

ts
import { McObject } from 'mxcad'

const mxcad = new McObject()
const mxdraw = mxcad.getMxDrawObject()

getSysVarDouble

getSysVarDouble(varName): number

Get floating-point values of system variables

Parameters

NameTypeDescription
VarNamestringVariable Name

Returns

number

Floating point values of variables


getSysVarLong

getSysVarLong(varName): number

Get the integer value of a system variable

Parameters

NameTypeDescription
VarNamestringVariable Name

Returns

number

The integer value of a variable


getSysVarPoint

getSysVarPoint(varName): McGePoint3d

Obtain the point values of system variables

Parameters

NameTypeDescription
VarNamestringVariable Name

Returns

McGePoint3d

Point values of variables


getSysVarString

getSysVarString(varName): string

Retrieve the string value of a system variable

Parameters

NameTypeDescription
VarNamestringVariable Name

Returns

string

The string value of a variable


getViewCADCoord

getViewCADCoord(): Object

Return the display range and CAD coordinates of the current viewport.

Returns

Object

Current viewport display range

NameType
pt1McGePoint3d
pt2McGePoint3d
pt3McGePoint3d
pt4McGePoint3d

iniAuthorizedService

iniAuthorizedService(sUrl): void

Initialize user authorization service url

Parameters

NameType
sUrlstring

Returns

void


init

init(imp): void

Initial object

Parameters

NameTypeDescription
Implement the 'imp''any'object, and by default, this function will be automatically called by the system

Returns

void


initMxObject

initMxObject(mxObject): void

Initialize object model

Parameters

NameTypeDescription
MxObjectanyInitialize [mxdraw]( https://mxcadx.gitee.io/mxdraw_docs )Created drawing controls

Returns

void

Description


initRegist

initRegist(sRegist): void

Initialize user registration data

Parameters

NameTypeDescription
SRegiststringRegistration data

Returns

void


insertBlock

insertBlock(sFileUrl, sBlkName, isWorkThread?, fetchAttributes?, isUpdataInsertBlock?, isUpdataSameNameBlock?): Promise<McObjectId>

Plugin block file

Parameters

NameTypeDefault valueDescription
SFileURLstringundefinedNetwork file path This file is in mxweb format
SBlkNamestringundefinedThe block name of the inserted block
IsWorkThreadbooleantrueWhether to use a worker thread to open the file, default to true
fetchAttributesnumber01: EMSCRIPTEN_FETCH_LOAD_TO_MEMORY, Load the drawing data into memory, 0: EMSCRIPTEN_FETCH_LOAD_TO_MEMORY | EMSCRIPTEN_FETCH_PERSIST_FILE | EMSCRIPTEN_FETCH_APPEND, Add the drawing data to IndexedDB
IsUpdataInsertBlockbooleanfalseUpdate existing blocks, default not updated
IsUpdataSameNameBlockbooleanfalseDuring the process of inserting a block, if a block with the same name is found in the original database, will it also be updated? By default, it will not be updated

Returns

Promise<McObjectId>

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
const blkrecId = await mxcad.insertBlock("./blkrec.mxweb", "sBlkName");

isTryVersion

isTryVersion(): boolean

Is the current program a trial version

Returns

boolean


loadDwgBackground

loadDwgBackground(sFileUrl, call, color?, isShow?): void

Load another DWG file to draw the current background object

Parameters

NameTypeDefault value
sFileUrlstringundefined
call(ret: boolean) => voidundefined
colornumber0
isShowbooleantrue

Returns

void


loadImage

loadImage(imageUrl, call, imageFileName?): void

Load an external image into the current context for future use.

Parameters

NameTypeDefault valueDescription
ImageURLstringundefinedImage path
Call(image: any)=>voidundefinedcallback function
imageFileNamestring""-

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"
 const mxcad: McObject = MxCpp.getCurrentMxCAD()
 mxcad.loadImage(imagUrl, (image) => {
   if (!image) {
       console.log("loadImage failed");
       return;
   }
   let width = mxcad.mxdraw.viewCoordLong2Cad(100);
   let height = (image.height / image.width) * width;
   idImage = mxcad.drawImage((pt as any).x, (pt as any).y, width, height, 0, imagUrl,true);
   mxcad.updateDisplay();
});

newFile

newFile(): boolean

Clear the content of the current image and create a new file

Returns

boolean

Example

ts
import { MxCpp, McObject } from "mxcad" ;

let mxcad:McObject = MxCpp.getCurrentMxCAD();
mxcad.newFile();

objectIdToObject

objectIdToObject(lIdIndex): null | McDbObject

Convert lIdInDex to McDbObject object

Parameters

NameTypeDescription
LIdIDEXnumberObject ID

Returns

null | McDbObject

McDbObject object corresponding to ID, returns null if the object does not exist


off

off(name, fun?): void

Turn off event monitoring

Parameters

NameTypeDescription
NameStringListening Event Name
fun?[Function]( https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Function )Monitoring events

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"

const mxcad:McObject = MxCpp.getCurrentMxCAD();
//E: Event function, referring to the function registered in mxcad. on ("selectChange", e)
mxcad.off("selectChange", e);

on

on(name, fun): void

Monitor object selection event

Parameters

NameType
name"selectChange"
fun(ids: McObjectId[]) => void | (ids: McObjectId[]) => void[]

Returns

void

Example

ts
import { MxCpp, McObject, McObjectId } from "mxcad"

const mxcad:McObject = MxCpp.getCurrentMxCAD();
mxcad.on("selectChange", (ids: McObjectId[])=> {
     if (ids.length == 0) return;
     let id = ids[0]
     let ent = id.getMcDbEntity()
     if(!ent) return
     console.log(ent.objectName)
})

on(name, fun): void

Monitor file fully open

Parameters

NameType
name"openFileComplete"
fun() => void

Returns

void

on(name, fun): void

Monitoring project initialization

Parameters

NameType
name"init"
fun() => void

Returns

void

on(name, fun): void

Monitor MXdraw initialization

Parameters

NameType
name"init_mxdraw"
fun(mxdraw: MxDrawObject) => void

Returns

void

on(name, fun): void

Monitor events before mxdraw initialization

Parameters

NameType
name"init_before_mxdraw"
fun(mxdraw: MxDrawObject) => void

Returns

void

on(name, fun): void

Monitor MXCAD initialization

Parameters

NameType
name"init_mxcad"
fun(mxcad: McObject) => void

Returns

void

on(name, fun): void

Monitor database modification events

Parameters

NameType
name"databaseModify"
fun() => void

Returns

void

on(name, fun): void

System variables have been modified

Parameters

NameType
name"sysVarChanged"
fun(name: string) => void

Returns

void

on(name, fun): void

Graphic database initialization

Parameters

NameType
name"databaseInitialization"
fun() => void

Returns

void

on(name, fun): void

The layer data has changed

Parameters

NameType
name"layerChanged"
fun() => void

Returns

void

on(name, fun): void

The line type data has changed

Parameters

NameType
name"lineTypeChanged"
fun() => void

Returns

void


openWebFile

openWebFile(sFileUrl, retCall?, isWorkThread?, initialParameter?, fetchAttributes?, isFetchTzFile?): boolean

Open network files

Parameters

NameTypeDefault valueDescription
SFileURLstringundefinedNetwork file path
retCall?(iRet: number)=>voidundefinedcallback function, optional parameter, callback function after opening the file, parameter is the result of opening the file, 0 indicates success, other values indicate failure
IsWorkThreadbooleantrueWhether to use a worker thread to open the file, default to true
initialParameter?objectundefined-
fetchAttributesnumber01: EMSCRIPTEN_FETCH_LOAD_TO_MEMORY, Load the drawing data into memory, 0: EMSCRIPTEN_FETCH_LOAD_TO_MEMORY | EMSCRIPTEN_FETCH_PERSIST_FILE | EMSCRIPTEN_FETCH_APPEND, Add the drawing data to IndexedDB
isFetchTzFilebooleantrue-

Returns

boolean

Did you successfully open the file

Example

ts
import { MxCpp } from "mxcad";
const mxcad = MxCpp.getCurrentMxCAD();
mxcad.openWebFile("http://localhost:1337/mxcad/file/a9cbed3d3a351b79f24484e87bd78338.DWG.mxweb");

pathCircle

pathCircle(dCenX, dCenY, dR, dPrecision?, dWidth?): boolean

Create a path based on a circular object

Parameters

NameTypeDefault value
dCenXnumberundefined
dCenYnumberundefined
dRnumberundefined
dPrecisionnumber0.0
dWidthnumber0

Returns

boolean

Example

ts
import { MxCpp, McObject } from "mxcad"
  const mxcad:McObject = MxCpp.getCurrentMxCAD()
  mxcad.pathCircle(0, 0, 20);

pathLineTo

pathLineTo(dX, dY): void

Draw a straight line from the current position to the specified location

Parameters

NameTypeDescription
DXnumberX coordinate
DYnumberY coordinate

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.pathLineTo(100, 300);

pathLineToEx

pathLineToEx(dX, dY, dStartWidth, dEndWidth, dBulge): void

Draw a straight line from the current position to the specified position, while specifying the starting width, ending width, and convexity

Parameters

NameTypeDescription
DXnumberX coordinate
DYnumberY coordinate
DStartWidthnumberStarting width
DEndWidthnumberEnd width
DBulgenumberconvexity

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.pathLineToEx(1000, 500, 30, 0, 0);

pathMakeClosed

pathMakeClosed(): void

Closed path

Returns

void


pathMakeExclude

pathMakeExclude(isExclude): void

Mark the current path as an exclusion marker, mainly used for filling and drawing. Dig out the closed area composed of this path in the filling process

Parameters

NameTypeDescription
IsExcludebooleanExclude or not

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"
   const mxcad:McObject = MxCpp.getCurrentMxCAD()
//Draw a solid object with a curved boundary filling, and cut a piece in the middle
   mxcad.pathMoveToEx(440, 3310, 0, 0, 0);
   mxcad.pathLineTo(480, 3310);
   mxcad.pathLineTo(480, 3360);
   mxcad.pathLineTo(450, 3340);
//Fill in the exclusion area with the path definition defined above
   mxcad.pathMakeExclude(true);

pathMoveTo

pathMoveTo(dX, dY): void

Move the path to the specified location

Parameters

NameTypeDescription
DXnumberX coordinate
DYnumberY coordinate

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.pathMoveTo(0, 300);

pathMoveToEx

pathMoveToEx(dX, dY, dStartWidth, dEndWidth, dBulge): void

Move the path to the specified location, while specifying the starting width, ending width, and convexity

Parameters

NameTypeDescription
DXnumberX coordinate
DYnumberY coordinate
DStartWidthnumberStarting width
DEndWidthnumberEnd width
dBulgenumber-

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.pathMoveToEx(1000, 300, 10, 10, 0);

redo

redo(): void

Reverse rollback, redo.

Returns

void


regen

regen(delayTime?): void

After redrawing all objects on the graph and calling ZoomAll and ZoomW, it may be necessary to delay the call to Regen before it takes effect due to asynchronous execution.

Parameters

NameTypeDefault value
delayTimenumber0

Returns

void

Example

ts
import { MxCpp, McObject } from 'mxcad'
 const mxcad:McObject = MxCpp.getCurrentMxCAD()
//Draw a circle with width
   mxcad.addLinetype("CircleLineType", "30,-5,7,-7");

//Design the current line type as' CircleLineType '
   mxcad.drawLinetype = ("CircleLineType");

   mxcad.drawLineWidth = 40;

   mxcad.drawCircle(600, 800, 120);

   mxcad.zoomAll();
   mxcad.regen();
   mxcad.updateDisplay();

saveFile

saveFile(filename?, call?, isDownland?, isShowSaveFileDialog?, parameter?): boolean

Save file

Parameters

NameTypeDefault valueDescription
filename?` StringundefinedSave as new file name
call?(data: any)=>voidundefinedcallback function, optional parameter, callback function after saving the file, parameter is file data
IsDownlandbooleantrueWhether to download files, default to true
IsShowSaveFileDialoguebooleantrueWhether to display the save file dialog box, default is true
parameter?objectundefined-

Returns

boolean

Has the file been successfully saved

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.App.getCurrentMxCAD()
const fileName =  mxcad.getCurrentFileName()
mxcad.saveFile("test", (data)=> {
  const blob = new Blob([data.buffer], { type: "application/octet-stream" });
}, false, false)

saveFileToUrl

saveFileToUrl(sSaveProgramUrl, call, filename?, param?): boolean

Save and convert the file to a network path for download

Parameters

NameTypeDescription
SSaveProgramURLstringBackend POST request interface, specific implementation of the interface: First download the MxDraw cloud map development package< https://www.mxdraw.com/download.html >And unzip and find MxDrawCloudServer \ Bin \ MXCAD \ MXCADSaveFile \ serverless. js. You can find the corresponding implementation interface "/mxcad/savefiledwg", "/mxcad/savefiledwg": save the dwg file to the server "/mxcad/savefile": save the mxweb file to the server. If not found, search for the definition of this interface under this project. It must comply with the definition of this interface to be used as a parameter
Call(iResult: number, ServerResult: string)=>voidSave file result callback. The parameters received here should be based on the location where the drawing is saved according to the interface definition, Ref.file is not the complete request path, it is only the name of the saved drawing
filename?string-
param?any-

Returns

boolean

Has the file been successfully saved

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
 MxCpp.getCurrentMxCAD().saveFileToUrl("http://localhost:3337/mxcad/savefiledwg", (iResult, sserverResult) => {
   let ret = JSON.parse(sserverResult);
   if (ret.ret == "ok") {
       console.log(ret.file)
   }
})

setAttribute

setAttribute(val): boolean

Set some property settings for objects

Parameters

NameTypeDescription
ValobjectProperty setting content 1. Display Precision display precision setting, default is 0, can take 0~10001000 as the highest precision. 2 Enable undo to enable undo function, which is not started by default

Returns

boolean

Example

ts
Enable undo
mxcad.setAttribute({EnableUndo:true})

setBrowse

setBrowse(browse): void

Set browsing mode

Parameters

NameType
browseboolean

Returns

void


setCurrentFileName

setCurrentFileName(fileName): void

Set the current file name

Parameters

NameType
fileNamestring

Returns

void


setCurrentLayout

setCurrentLayout(layoutName): void

Set the current layout name

Parameters

NameTypeDescription
LayoutNamestringLayout Name

Returns

void


setCurrentOriginaFileName

setCurrentOriginaFileName(fileName): void

Set the current file name

Parameters

NameType
fileNamestring

Returns

void


setSysVarDouble

setSysVarDouble(varName, val): boolean

Set floating-point values for system variables

Parameters

NameTypeDescription
VarNamestringVariable Name
ValnumberFloating point value of variable

Returns

boolean

Whether the variable value has been successfully set


setSysVarLong

setSysVarLong(varName, val): boolean

Set integer values for system variables

Parameters

NameTypeDescription
VarNamestringVariable Name
ValnumberThe integer value of a variable

Returns

boolean

Whether the variable value has been successfully set


setSysVarPoint

setSysVarPoint(varName, pt): boolean

Set the point values of system variables

Parameters

NameTypeDescription
VarNamestringVariable Name
ptMcGePoint3d-

Returns

boolean

Whether the variable value has been successfully set


setSysVarPoint2d

setSysVarPoint2d(varName, pt): boolean

Set 2D point values for system variables

Parameters

NameTypeDescription
VarNamestringVariable Name
ptMcGePoint3d-

Returns

boolean

Whether the variable value has been successfully set


setSysVarString

setSysVarString(varName, val): any

Set string values for system variables

Parameters

NameTypeDescription
VarNamestringVariable Name
ValstringThe string value of the variable

Returns

any

Whether the variable value has been successfully set


setViewBackgroundColor

setViewBackgroundColor(red, green, blue): void

Set the background color of the viewport

Parameters

NameType
rednumber
greennumber
bluenumber

Returns

void

Example

ts
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.setViewBackgroundColor(255, 255, 255)

showLineWeight

showLineWeight(isShow): boolean

Display line weight

Parameters

NameType
isShowboolean

Returns

boolean


undo

undo(): void

Go back to the previous command or tag

Returns

void


undoMark

undoMark(): void

Set a rollback flag at the current time

Returns

void


updateDisplay

updateDisplay(isImmediate?, delayTime?): void

update display

Parameters

NameTypeDefault valueDescription
IsImmediatebooleanfalseUpdate now
DelayTimenumber0Delay update time

Returns

void


updateLayerDisplayStatus

updateLayerDisplayStatus(): void

Update the display of layers

Returns

void


zoomAll

zoomAll(autoRegen?): boolean

Show all

Parameters

NameTypeDefault value
autoRegenbooleanfalse

Returns

boolean


zoomAngle

zoomAngle(viewangle): void

Set the angle of the display viewport, in PI units

Parameters

NameTypeDescription
ViewanglenumberRotation angle Math PI

Returns

void

void

Example

typescript
import { MxCpp, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.zoomAngle(Math.PI / 2)

zoomCenter

zoomCenter(dCenX, dCenY): void

Move the current display range to the specified position, dCenX, dCenY are DWG drawing coordinates.

Parameters

NameType
dCenXnumber
dCenYnumber

Returns

void

void

Example

typescript
import { MxCpp, McGePoint3d, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.zoomCenter(0, 0)

zoomScale

zoomScale(scale): void

Scale the current display range, which is relative to the current display range

Parameters

NameTypeDescription
Scalenumberscale scaling ratio

Returns

void

void

Example

ts
import { MxCpp, McObject } from 'mxcad'
 const mxcad:McObject = MxCpp.getCurrentMxCAD()
   mxcad.drawLine(350, 220, 600, 220);
   mxcad.zoomScale(o.6);

zoomW

zoomW(minPt, maxPt): void

Move the current display range to the specified display range

Parameters

NameTypeDescription
MinPt[McGePoint3d] (2d. McGePoint3d. md)Coordinate 1 McGePoint3d
MaxPt[McGePoint3d] (2d. McGePoint3d. md)Coordinates 2 McGePoint3d

Returns

void

void

Example

typescript
import { MxApp, McGePoint3d, McObject } from "mxcad"
const mxcad:McObject = MxCpp.getCurrentMxCAD()
mxcad.zoomW(new McGePoint3d(0, 0), new McGePoint3d(30, 30))