CorelDRAW VBA探秘

CorelDRAW VBA - 读取XML文件,根据内容批量创建

2018-01-10  本文已影响0人  成都超平面科技

公告


本专栏的相关的文章已不在简书同步更新,请直接访问 VBA探秘 官方网站或关注微信公众号获取最新文章动态。

coreldraw-vba-read-xml-file

目的

这篇教程将教会你如何使用 CorelDRAW VBA 来读取 XML 文件,并通过读取的内容来动态创建指定宽度和高度的矩形。

准备一个XML文件

打开记事本,粘贴以下内容,然后保存文件,文件名输入 shape.xml,保存类型选择“所有文件”。将这个文件保存到 d:\temp\shape.xml 或者你指定的其他位置(如果使用自定义位置,请在下面的VBA代码中修改成自己的XML文件路径)。

在这个XML文件中,我们使用 shape 节点记录了一个矩形的简单信息,包括 width(宽度)、height(高度)和 title(标题),一共定义了 3 个简单的矩形信息,内容如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<shapes>
    <shape>
        <width>200</width>
        <height>100</height>
        <title>矩形1</title>
    </shape>
    <shape>
        <width>300</width>
        <height>180</height>
        <title>矩形2</title>
    </shape>
    <shape>
        <width>400</width>
        <height>220</height>
        <title>矩形3</title>
    </shape>
</shapes>

在宏编辑器中粘贴以下代码

如果你还不知道怎么创建自己的宏工程(GMS工程),请先阅读 CorelDRAW VBA - 创建GMS宏工程 这篇文章,然后将下面的代码拷贝并运行。

'========================================================================================
' 主函数(默认对外暴露的运行入口)
' @author: Zebe
' @date: 2017/12/11
'========================================================================================
Sub main()
    readXMLAndCreateShape "d:\temp\shape.xml" ' 调用过程(请注意XML文件路径)
End Sub

'========================================================================================
' 读取XML文件并创建图形
' @author: Zebe
' @date: 2017/12/11
'========================================================================================
Private Sub readXMLAndCreateShape(filePath As String)
    ' 载入XML文件
    Dim xmlDom
    Set xmlDom = CreateObject("MSXML.DOMDocument")
    xmlDom.Load (filePath)
    xmlDom.async = False ' 关闭异步读取,设置为同步读取(即:这句代码会阻塞,直到文件读取完)

    ' 节点变量声明
    Dim shapeNodes, widthNodes, heightNodes, titleNodes
    Set shapeNodes = xmlDom.SelectNodes("//shape")
    Set widthNodes = xmlDom.SelectSingleNode("//width")
    Set heightNodes = xmlDom.SelectSingleNode("//height")
    Set titleNodes = xmlDom.SelectSingleNode("//title")

    ' 遍历所有shape节点
    Dim i As Integer, j As Integer
    For i = 0 To shapeNodes.Length - 1
        ' 取出每个shape节点下的子节点(根据索引序号去取)
        Dim width As Integer, height As Integer, title As String
        width = shapeNodes.Item(i).ChildNodes(0).Text
        height = shapeNodes.Item(i).ChildNodes(1).Text
        title = shapeNodes.Item(i).ChildNodes(2).Text
        'MsgBox ("width=" & width & ", height=" & height & ", title=" & title)
        createShape width, height, title
    Next i
    
    ' 释放已经加载的DOM对象所占用的内存
    Set xmlDom = Nothing
End Sub

'========================================================================================
' 创建图形(这个方法中没有用到 title 参数,可根据需要使用,例如设置备注)
' @author: Zebe
' @date: 2017/12/11
'========================================================================================
Private Sub createShape(width As Integer, height As Integer, title As String)
    ' 如果没有活动文档,则自动创建一个文档,并设置文档单位为mm
    If ActiveDocument Is Nothing Then
        Application.CreateDocument
        ActiveDocument.Unit = cdrMillimeter
    End If
    ' 在页面左下角(坐标0,0)开始,创建指定宽高的矩形
    ActiveDocument.ActivePage.ActiveLayer.CreateRectangle2 0, 0, width, height
End Sub

代码说明


原创声明:本文首发于个人CorelDRAW VBA博客,请尊重文章版权。
转载请注明原文链接:http://www.cdrvba.com/coreldraw-vba-read-xml-file/

上一篇 下一篇

猜你喜欢

热点阅读