2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
खण्डाः CAD इत्यस्मिन् अतीव महत्त्वपूर्णः ज्ञानबिन्दुः अस्ति अद्य अहं भवद्भ्यः खण्डानां किञ्चित् वर्गीकरणं परिचयं च दास्यामि, तथैव खण्डानां परिभाषां सन्दर्भं च दास्यामि।
खण्डः बहुभिः तार्किकरूपेण सम्बद्धैः चित्रात्मकैः वस्तुभिः परिभाषितः सत्ता अस्ति । लाभः अस्ति यत् एतत् कार्यमानकान् एकीकृत्य कार्यदक्षतां सुधारयितुम् अर्हति, यतः जीवने कश्चन वस्तु सरलः एककः नास्ति, परन्तु बहुभिः एककैः निर्मितः भवितुम् अर्हति खण्डाः एतस्याः संरचनायाः सम्यक् प्रतिनिधित्वं कर्तुं शक्नुवन्ति
खण्डस्य सारः खण्डसारणी अभिलेखेषु संगृहीतानाम् सत्तावस्तूनाम् सङ्ग्रहः भवति ।
विशेषताखण्डाः गठितसत्ताभिः अतिरिक्तसूचनैः (गुणैः) च निर्मिताः भवन्ति श्रेणी। । विशिष्टानि कार्यान्वयनम् अन्तर्भवन्ति : १.
तेषु विशेषताभिः परिभाषिताः विशेषतामूल्यानि मुख्यतया अन्तर्भवन्ति-
गतिशीलखण्डाः अस्मान् उच्चस्तरीयलचीलतायाः अनुकूलनक्षमतायाः च खण्डान् निर्मातुं शक्नुवन्ति । यतः एकदा पारम्परिकः खण्डः रेखाचित्रे प्रविष्टः भवति तदा तस्य आकारः, आकारः, स्थानं च प्रायः नियतं भवति । गतिशीलखण्डाः तु सम्पूर्णं खण्डं पुनः परिभाषितुं वा तस्य घटकान् मैन्युअल् रूपेण सम्पादयितुं वा विना उपयोक्तृ-अन्तरफलक-अन्तरक्रियायाः माध्यमेन (यथा क्रिया-हन्डल-कर्षणम्) स्वस्य ज्यामितीय-गुणान् समायोजयितुं शक्नुवन्ति
खण्डाः मुख्यतया सरलखण्डाः, विशेषताखण्डाः, गतिशीलखण्डाः च इति विभक्ताः भवन्ति । खण्डानां कृते मुख्यतया खण्डपरिभाषाक्रियाः, खण्डसन्दर्भक्रियाः (अर्थात् खण्डप्रवेशक्रियाः), खण्डसम्पादनं च सन्ति ।
ते कीदृशाः खण्डाः न भवेयुः, तेषां परिभाषाः मोटेन समानाः सन्ति (विशेषणखण्डेषु विशेषतावस्तूनि योजयितुं आवश्यकाः सन्ति) ।
विशिष्टः कोडः यथा अस्ति ।
public static ObjectId AddBlockThroughDB(this Database db, string blockName, List<Entity> ents)
{
//声明ObjectId,用于返回
ObjectId entId = ObjectId.Null;
using (Transaction tr = db.TransactionManager.StartTransaction())
{
BlockTable bt = (BlockTable)db.BlockTableId.GetObject(OpenMode.ForWrite);
BlockTableRecord btr = new BlockTableRecord();
btr.Name = blockName;
for (int ii = 0; ii < ents.Count; ii++)
{
Entity ent = ents[ii];
btr.AppendEntity(ent);
}
entId = bt.Add(btr);
tr.AddNewlyCreatedDBObject(btr, true);
tr.Commit();
}
return entId;
}
उपरिष्टाद् केवलं सरलस्य खण्डस्य परिभाषा अस्ति यदा सन्दर्भ्यते)।
Property block definition, वयं तस्मिन् properties योजयित्वा properties योजयितुं शक्नुमः ।
/// <summary>
/// 块添加属性
/// </summary>
/// <param name="blockId"></param>
/// <param name="atts"></param>
public static void AddAttsToBlocks(this ObjectId blockId, List<AttributeDefinition> atts)
{
Database db = blockId.Database;//获取数据库对象
BlockTableRecord btr = blockId.GetObject(OpenMode.ForWrite) as BlockTableRecord;
foreach (AttributeDefinition att in atts)
{
btr.AppendEntity(att);
db.TransactionManager.AddNewlyCreatedDBObject(att, true);
}
btr.DowngradeOpen();
}
public static void AddAttsToBlocks(this ObjectId blockId, params AttributeDefinition[] atts)
{
blockId.AddAttsToBlocks(atts.ToList());
}
निर्दिष्टे खण्डपरिभाषायां विशेषताः योजयति । वयं तस्य उपयोगं एतादृशं कर्तुं शक्नुमः : १.
//属性添加
AttributeDefinition attr1 = new AttributeDefinition(Point3d.Origin, "箱变", "箱变编号", "请输入箱变编号", ObjectId.Null);
AttributeDefinition attr2 = new AttributeDefinition(Point3d.Origin + new Vector3d(0, 0.25, 0),
"变电站", "变电站编号", "请输入变电站编号", ObjectId.Null);
//然后将这两个属性加入到集合,再调用上面的方法即可。
पैरामीटर् वर्णनं निम्नलिखितम् अस्ति ।
गतिशीलखण्डानां परिभाषायां विशेषताखण्डानां उपयोगः आवश्यकः भवति ।DynamicBlockReferencePropertyCollection
वर्गाः गुणानाम् उपरि बाधाः आरोपयन्ति ।
public void Insert()
{
Database db = HostApplicationServices.WorkingDatabase;
using (Transaction trans = db.TransactionManager.StartTransaction())
{
BlockTable bt = (BlockTable)db.BlockTableId.GetObject(OpenMode.ForRead);
BlockTableRecord space = db.CurrentSpaceId.GetObject(OpenMode.ForWrite) as BlockTableRecord;
//判断名为“块1”的块是否存在
if(! bt["块1"].IsNull)
{
BlockReference br = new BlockReference(Point3d.Origin, bt["块1"]);
br.ScaleFactors = new Scale3d(2.0);//设置尺寸为原来2倍
space.AppendEntity(br);
trans.AddNewlyCreatedDBObject(br, true);
trans.Commit();
}
else
{
return;
}
}
}
ब्लॉकसन्दर्भे विशेषतासत्ता DatabaseServices नामस्थाने AttibuteReference वर्गेन प्रतिनिधिता भवति, यत् वस्तुतः DBText वर्गात् व्युत्पन्नं एकपङ्क्तिपाठवस्तु अस्ति ब्लॉकसन्दर्भे विशेषताः योजयितुं एतानि पदानि अनुसृत्य कार्यं कुर्वन्तु ।
/// <summary>
/// 插入带属性的参照快
/// </summary>
/// <param name="spaceId">空间的ID</param>
/// <param name="layer">块要加入的图层名</param>
/// <param name="blockName">快参照所属的快名</param>
/// <param name="postion">插入点</param>
/// <param name="scale">缩放比例</param>
/// <param name="rotateAngle">旋转角度</param>
/// <param name="attNameValues">属性名称与取值</param>
/// <returns></returns>
public static ObjectId InsertBlockrefence(this ObjectId spaceId, string layer, string blockName, Point3d postion, Scale3d scale, double rotateAngle, Dictionary<string, string> attNameValues)
{
// 获取数据库对象
Database db = spaceId.Database;
//以读的方式打开块表
BlockTable bt = db.BlockTableId.GetObject(OpenMode.ForRead) as BlockTable;
//如果没有blockName d的块,则程序返回
if (!bt.Has(blockName))
return ObjectId.Null;//如果没有blockName的块,程序返回
//以写的模式打开空间
BlockTableRecord space = (BlockTableRecord)spaceId.GetObject(OpenMode.ForWrite);
//获取块表的记录ID
ObjectId btrId = bt[blockName];
//打开块表记录
BlockTableRecord record = btrId.GetObject(OpenMode.ForRead) as BlockTableRecord;
//创建一个快参照并设置插入点
BlockReference br = new BlockReference(postion, bt[blockName]);
br.ScaleFactors = scale;
br.Layer = layer;
br.Rotation = rotateAngle;
space.AppendEntity(br);
//判断块表记录是否包含属性定义
if (record.HasAttributeDefinitions)
{
//若包含,则遍历属性定义
foreach (ObjectId id in record)
{
//检查是否是属性定义
AttributeDefinition attDef = id.GetObject(OpenMode.ForRead) as AttributeDefinition;
if (attDef != null)
{
//创建一个新的属性对象
AttributeReference attribute = new AttributeReference();
//从属性定义获取属性对象的对象特性
attribute.SetAttributeFromBlock(attDef, br.BlockTransform);
attribute.Rotation = attDef.Rotation;
attribute.Position = attDef.Position.TransformBy(br.BlockTransform);
attribute.AdjustAlignment(db);
//判断是否包含指定的属性名称
if (attNameValues.ContainsKey(attDef.Tag.ToUpper()))
{
//设置属性值
attribute.TextString = attNameValues[attDef.Tag.ToUpper()].ToString();
}
// 向块参照添加属性对象
br.AttributeCollection.AppendAttribute(attribute);
db.TransactionManager.AddNewlyCreatedDBObject(attribute, true);
}
}
}
db.TransactionManager.AddNewlyCreatedDBObject(br, true);
return br.ObjectId;//返回添加的快参照的ID
}
उपर्युक्तेषु केषाञ्चन मापदण्डानां आवश्यकता न भवेत्, यथा स्केलिंग् रेश्यो, इन्सर्शन रेश्यो च ।
/// <summary>
/// 更新属性名称与取值
/// </summary>
/// <param name="blockRefId"></param>
/// <param name="attNameValues"></param>
public static void UpdateAttributesInBlock(this ObjectId blockRefId, Dictionary<string, string> attNameValues)
{
BlockReference blockRef = blockRefId.GetObject(OpenMode.ForRead) as BlockReference;
if (blockRef != null)
{
foreach (ObjectId id in blockRef.AttributeCollection)
{
AttributeReference attref = id.GetObject(OpenMode.ForRead) as AttributeReference;
if (attNameValues.ContainsKey(attref.Tag.ToUpper()))
{
attref.UpgradeOpen();
//设置属性值
attref.TextString = attNameValues[attref.Tag.ToUpper()].ToString();
attref.DowngradeOpen();
}
}
}
}