模型中发生的每一个变化都是事务的一部分,这是我们设计的核心。所有事务都是由 IModel 的实现创建的,并且从中被弱引用,因此当使用 using 语句模型时,只要保留事务,就只保留对该事务的引用。这意味着有一个单一的点,所有的变化都在发生,我们可以用它们来做一些事情。

  一件很重要的事情是记录所有的更改、以前的状态和下一个状态。将所有这些结合起来,您可以创建 back-log 或 forward-log。为了简化这个任务,我们实现了一个 xbim.io.delta.TransactionLog 类。在下面的示例中,我们将了解如何使用它。

  1. using System;
  2. using Xbim.Common;
  3. using Xbim.Ifc;
  4. using Xbim.Ifc4.Interfaces;
  5. using Xbim.IO.Delta;
  6. using Xbim.IO.Step21;
  7.  
  8. var editor = new XbimEditorCredentials
  9. {
  10. ApplicationDevelopersName = "You",
  11. ApplicationFullName = "Your app",
  12. ApplicationIdentifier = "Your app ID",
  13. ApplicationVersion = "4.0",
  14.  
  15. EditorsFamilyName = "Santini Aichel",
  16. EditorsGivenName = "Johann Blasius",
  17. EditorsOrganisationName = "Independent Architecture"
  18. };
  19.  
  20. using (var model = IfcStore.Open("SampleHouse.ifc", editor, true))
  21. {
  22. using (var txn = model.BeginTransaction("Modification"))
  23. {
  24. using (var log = new TransactionLog(txn))
  25. {
  26. // 修改一个已经存在的 墙 对象
  27. var wall = model.Instances.FirstOrDefault<IIfcWall>();
  28. wall.Name = "Unexpected name";
  29. wall.GlobalId = Guid.NewGuid().ToPart21();
  30. wall.Description = "New and more descriptive description";
  31.  
  32. // 打印所有由此引起的更改
  33. PrintChanges(log);
  34. txn.Commit();
  35. }
  36. Console.WriteLine();
  37. }
  38. }
  1. private static void PrintChanges(TransactionLog log)
  2. {
  3. foreach (var change in log.Changes)
  4. {
  5. switch (change.ChangeType)
  6. {
  7. case ChangeType.New:
  8. Console.WriteLine(@"New entity: {0}", change.CurrentEntity);
  9. break;
  10. case ChangeType.Deleted:
  11. Console.WriteLine(@"Deleted entity: {0}", change.OriginalEntity);
  12. break;
  13. case ChangeType.Modified:
  14. Console.WriteLine(@"Changed Entity: #{0}={1}", change.Entity.EntityLabel, change.Entity.ExpressType.ExpressNameUpper);
  15. foreach (var prop in change.ChangedProperties)
  16. Console.WriteLine(@" Property '{0}' changed from {1} to {2}", prop.Name, prop.OriginalValue, prop.CurrentValue);
  17. break;
  18. default:
  19. break;
  20. }
  21. }
  22. }

生成的更改日志将如下所示。它包含更多的更改,因为当您更改或创建任何ifcroot实体时,xbim会自动为您处理所有者历史记录。

  1. Changed Entity: #=IFCWALL
  2. Property 'Name' changed from 'Basic Wall:Wall-Ext_102Bwk-75Ins-100LBlk-12P:285330' to 'Unexpected name'
  3. Property 'OwnerHistory' changed from # to #
  4. Property 'GlobalId' changed from '3cUkl32yn9qRSPvBJVyWw5' to '0zxW3$9z95n8U_H9YOcyiE'
  5. Property 'Description' changed from $ to 'New and more descriptive description'
  6. New entity: #=IFCOWNERHISTORY(#,#,$,.MODIFIED.,$,$,$,);
  7. New entity: #=IFCPERSON($,'Santini Aichel','Johann Blasius',$,$,$,$,$);
  8. New entity: #=IFCORGANIZATION($,'Independent Architecture',$,$,$);
  9. New entity: #=IFCPERSONANDORGANIZATION(#,#,$);
  10. New entity: #=IFCORGANIZATION($,'You',$,$,$);
  11. New entity: #=IFCAPPLICATION(#,$,'Your app','Your app ID');
 

xBIM 高级03 更改日志创建的更多相关文章

  1. xBIM 基础03 基本模型操作

    系列目录    [已更新最新开发文章,点击查看详细]  本篇将使用基本的代码示例来表示如何使用xBIM.我们将介绍持久存储的四个基本功能,即 CRUD(创建,检索,更新和删除).以下示例通常适用于IF ...

  2. SAP更改日志记录表

    CDHDR  更改日志表头 CDPOS  更改日志行项目 SAP中修改频率较低的定制表(T001等)一般都会有修改记录存在,查看一个表有没有修改记录可以在SE11中查看他的技术设置,如果其中的LOG ...

  3. JS高级. 03 混入式继承/原型继承/经典继承、拓展内置对象、原型链、创建函数的方式、arguments、eval、静态成员、实例成员、instanceof/是否在同一个原型链

    继承:当前对象没有的属性和方法,别人有,拿来给自己用,就是继承 1 混入式继承 var I={ }; var obj = { name: 'jack', age:18, sayGoodbye : fu ...

  4. Nginx教程---03.Nginx日志切割

    Nginx的定时任务与自动切割 明确: 如果这个网站的访问量比较大,那么一天下来 nginx日志可能会特别的大,所以当出现这种情况呢,如果 把每天的日志都存在同一个日志文件里,会使你的日志文件大到让你 ...

  5. webdriver高级应用- 使用日志模块记录测试过程中的信息

    在自动化脚本执行过程中,使用Python的日志模块记录在测试用例执行过程中一些重要信息或者错误日志等,用于监控和后续调试脚本. 在pycharm下新建工程,并创建Log.py.Logger.conf以 ...

  6. xBIM 实战03 使用WPF技术实现IFC模型的加载与浏览

    系列目录    [已更新最新开发文章,点击查看详细]  WPF应用程序在底层使用 DirectX ,无论设计复杂的3D图形(这是 DirectX 的特长所在)还是绘制简单的按钮与文本,所有绘图工作都是 ...

  7. xBIM 高级02 插入复制功能

    系列目录    [已更新最新开发文章,点击查看详细]  IFC 模型中的合并和删除实体是一个非常重要的任务,因为 IFC 不是一个分层结构.它是一个复杂的结构,具有潜在的循环关系,是一个双向导航.在单 ...

  8. xBIM 高级01 IFC多模型合并

    系列目录    [已更新最新开发文章,点击查看详细]  多模型合并可以实现以下功能: 覆盖多个模型以表现得像一个模型 统一访问数据,就像它是单个模型一样 只读.要修改模型的内容,您必须使用特定模型 不 ...

  9. MySQL高级查询之索引创建、删除、增加、修改、慢sql、explain解释sql

    day04数据库 昨日知识点回顾 1.单表操作 1.单表的操作 条件查询的优先级别: where > group by >having > order by > limit; ...

随机推荐

  1. JavaScript学习笔记——对象的创建

    对象是JavaScript基本数据类型,在JavaScript中除了Undefined.Null.布尔型(ture.false).字符串和数字之外,其他的都属于对象. 在JavaScript中,一个对 ...

  2. 剑指offer——03从尾至头打印列表(Python3)

    思路:相当于数据结构中的链表就地逆置,可以使用头插法来实现. 代码: class Solution:     # 返回从尾部到头部的列表值序列,例如[1,2,3]     def printListF ...

  3. ROS-Solidworks转URDF

    前言:URDF建模很粗糙,而ros提供了支持sw转urdf的插件,可以使建模更精细化. 一.安装sw_urdf_exporter插件 sw_urdf_exporter插件网址:http://wiki. ...

  4. CentOS 6.7操作系统安装

    如果由于是显卡驱动不兼容的话,在选择安装界面按tab键,进入命令行,然后在命令行后加上 nodmraid 关键字回车开始安装. 接下来选择hard driver   选择最后一个分区进行系统安装,然后 ...

  5. Spark RDD概念学习系列之RDD接口

    不多说,直接上干货!

  6. 搭建简单的Habernate环境(一)

    一.开篇 下载Habernate所需要的jar包和mysql驱动. 二.建立java项目并且导入所需要的包 三.建立实体类和配置映射文件 user实体类 package testPackage; pu ...

  7. Android Handler学习笔记

    已经习惯了挖坑不填,继续任性一下,周一到周五继续挖坑,每周六周日负责填坑. 1.从Android UI线程谈起 出于性能考虑,Android 中的UI操作并不是线程安全的,所以Android中规定只能 ...

  8. CDR发展史-CorelDRAW经历了哪些版本?

    1989年CorelDRAW横空出世,它引入了全彩矢量插图和版面设计程序,这在计算机图形领域掀起了一场风暴般的技术革新.两年后,Corel又推出了首款一体化图形套件(第 3 版),将矢量插图.版面设计 ...

  9. 更新Maven的本地库

    1. 更新Maven的本地库 通常情况下,可改变默认的 .m2 目录下的默认本地存储库文件夹到其他更有意义的名称,例如, maven-repo 找到 {M2_HOME}\conf\setting.xm ...

  10. vue 表格数据编辑,点击取消或者完成按钮后,关闭编辑状态没有及时生效

    点击编辑按钮: 编辑状态下,表格可以编辑.但是点击“确认”或者“取消”按钮,列数据编辑状态已经修改,但是视图没有改变. 页面代码: 获取当前行的index,并直接修改当前行用于判断是否编辑状态的数据为 ...