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

公告


本专栏的相关的文章已不在简书同步更新,请直接访问 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

代码说明

  • Set xmlDom = CreateObject("MSXML.DOMDocument") 创建了一个XML文档模型对象
  • SelectNodes 方法用来选择某个节点集合
  • SelectSingleNode 方法用来选择单个节点
  • 节点集合.Item(i) 这种调用方法是用来访问某个节点集合中的第 i 个元素
  • ChildNodes(x) 用来获取某个节点的第 x 个子节点

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 公告 本专栏的相关的文章已不在简书同步更新,请直接访问 VBA探秘 官方网站或关注微信公众号获取最新文章动态。 目...
    成都超平面科技阅读 6,502评论 0 0
  • 1.1 VBA是什么 直到90年代早期,使应用程序自动化还是充满挑战性的领域.对每个需要自动化的应用程序,人们不得...
    浮浮尘尘阅读 22,070评论 6 49
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,136评论 25 709
  • 最近看电视了,感觉心情不一样了,前段时间吧!总感觉生活的特没劲,感觉活着就是受罪的,每天除了吃饭,睡觉,干活,工作...
    心灵的驰骋阅读 2,656评论 0 0
  • 我以为我可以很快忘了你 我以为这只是荷尔蒙 我以为你对我有意思 我以为好不容易遇到了喜欢的,就应该奋起直追 我以为...
    丸子的夏天阅读 2,790评论 6 0

友情链接更多精彩内容