XML文件基础

 

https://c3d.club/xml/basic/2018/12/27/xml-file-base.html

1.文件头

XML文件头有XML声明与DTD文件类型声明组成。其中DTD文件类型声明是可以缺少的,关于DTD声明这里不做介绍,而XML声明是必须要有的,以使文件符合XML的标准规格。

PackageContents.XML文件中的第一行代码几位XML的声明:

代表的意识是:

"" 代表一条指令的结束;

"xml"代表此文件是XML文件;

" version="1.0" "代表文件用的是XML1.0标准;

" encoding="utf-8" "代表此文件所用的字符集。

注意: XML声明必须出现在文档的第一行。

2.文件体

文件体中包含的是XML文件的内容,XML元素是XML文件内容的基本单元。从语法上讲,一个元素包含一个起始标记、一个结束标记以及标记之间的数据内容。

XML元素与HTML元素的格式基本相同,其格式如下:

<标记名称 属性名1="属性值1" 属性名2="属性值2"……>内容</标记名称>

所有数据内容都必须在某个标记的开始和结束标记内,而每个标记又必须包含在另一个标记的开始于结束标记内,形成嵌套式的分布,只有最外层的标记不必被其他的标记所包含。最外层的是根元素(Root),又称文件(Document)元素,所有的元素都包含在根元素内。

PackageContents.XML文件中,根元素就是,根元素必须而且只能有一个。SchemaVersion等元素为属性,CompanyDetails等元素为"内容",每条内容又有自己的属性及内容,多层嵌套。

PackageContents.XML文件中各元素有些是必须具备的,有些是可选的。

大部分的属性,通过其名称就能知道其作用,例如NameDescription等,下面支队个别元素的注意事项进行解释:

RuntimeRequirements元素,虽然是可选元素,但作者建议保留,理由如下:属性PlatformSeriesMinseriesMax可以指定插件的运行平台及版本。

例如在Civil 3D中运行相应的插件,可以通过设置Platform的值为Civil 3D实现,运行其他基于AutoCAD的产品时,该插件并不会被加载;如果所有基于AutoCAD的产品都加载此插件,可以通过设置Platform的值为AutoCAD*实现,即示例中所展示的状态。

SeriesMinSeriesMax限制了插件支持的AutoCAD版本,不同的AutoCAD版本,需要加载不同版本的插件,可以通过指定这两项元素的值来实现。示例中,SeriesMin="R19.1"SeriesMax="R22.0",表示从AutoCAD 2014版至AutoCAD 2018版均能加载此插件。如何查询产品名称中版本与内部版本之间的关系,可以利用命令AcadVer来实现。

另外一个需要注意的问题是文件路径均为相对路径,均相对于根.bundle文件夹。

除了以上的实例,读者还可以研究其他的软件包,例如Civil3DSnoopDB.bundle来了解程序包的结构及XML文件中的元素。

3.示例文件

PackageContents.XML

<?xml version="1.0" encoding="utf-8" standalone="no"?>

 

 

<ApplicationPackage

SchemaVersion="1.0"

AppVersion="4.70.9"

AutodeskProduct="AutoCAD"

Description="Autodesk BIM 360 Glue AutoCAD 2019 Add-in"

Author="Autodesk"

ProductCode="{F4C628E2-41FF-5AAF-8985-DA26BBF5FCB2}"

UpgradeCode="{D3A7FFB2-B829-4EA1-BD0C-E681847D1E92}"

Name="Autodesk BIM 360 Glue AutoCAD 2019 Add-in">

<RuntimeRequirements

OS="Win32|Win64"

Platform="AutoCAD|AutoCAD*"

SeriesMin="23.0"

SeriesMax="23.0" />

<CompanyDetails

Name="Autodesk"

Email="andrew.gleadall@autodesk.com" />

<Components

Description="Win32 parts">

<RuntimeRequirements

OS="Win32"

Platform="AutoCAD|AutoCAD*"

SeriesMin="23.0"

SeriesMax="23.0" />

<ComponentEntry

AppName="BIM360Glue"

AppType=".Net"

Version="4.70.9"

ModuleName="./Contents/Win32/BIM360GlueAutoCAD2019Addin.dll"

AppDescription="Main .NET Module"

LoadOnAutoCADStartup="True">

<Commands

GroupName="ADESK_BIM360GLUE">

<Command

Local="ShowBIM360"

Global="ShowBIM360"

Description="Command to show BIM360 plugin" />

<Command

Local="HideBIM360"

Global="HideBIM360"

Description="Command to hide BIM360 plugin" />

<Command

Local="Glue"

Global="Glue"

Description="Glue" />

<Command

Local="ClashPinpoint"

Global="ClashPinpoint"

Description="ClashPinpoint" />

<Command

Local="BIM360_Attach"

Global="BIM360_Attach"

Description="Attach" />

</Commands>

</ComponentEntry>

<ComponentEntry

AppName="BIM360Glue"

Version="4.70.9"

ModuleName="./Contents/Win32/BIM360GlueAddinsCommon.dll"

AppDescription="BIM360GlueAddinsCommon"

AppType="Dependency" />

 

<ComponentEntry

AppName="BIM360Glue"

Version="4.70.9"

ModuleName="./bim360.cuix" />

 

</Components>

<Components

Description="Win64 parts">

<RuntimeRequirements

OS="Win64"

Platform="AutoCAD|AutoCAD*"

SeriesMin="23.0"

SeriesMax="23.0" />

<ComponentEntry

AppName="BIM360Glue"

AppType=".Net"

Version="4.70.9"

ModuleName="./Contents/Win64/BIM360GlueAutoCAD2019Addin.dll"

AppDescription="Main .NET Module"

LoadOnAutoCADStartup="True">

<Commands

GroupName="ADESK_BIM360GLUE">

<Command

Local="addHorizontalRibbon"

Global="addHorizontalRibbon"

Description="addHorizontalRibbon" />

<Command

Local="removeHorizontalRibbon"

Global="removeHorizontalRibbon"

Description="removeHorizontalRibbon" />

<Command

Local="Glue"

Global="Glue"

Description="Glue" />

<Command

Local="ClashPinpoint"

Global="ClashPinpoint"

Description="ClashPinpoint" />

<Command

Local="BIM360_Attach"

Global="BIM360_Attach"

Description="Attach" />

</Commands>

</ComponentEntry>

<ComponentEntry

AppName="BIM360Glue"

Version="4.70.9"

ModuleName="./Contents/Win64/BIM360GlueAddinsCommon.dll"

AppDescription="BIM360GlueAddinsCommon"

AppType="Dependency" />

 

<ComponentEntry

AppName="BIM360Glue"

Version="4.70.9"

ModuleName="./bim360.cuix" />

 

</Components>

</ApplicationPackage>

原文地址:https://www.cnblogs.com/civil/p/10192836.html