Undo/Redo几种实现方式介绍(三)——保存操作方式

时间:2020-12-25 16:51:33
顾名思义,保存操作就是将用户对信息编辑界面的操作保存下来,包括操作对象、操作类型、操作前后的数据以及必要的辅助信息。不管是今天介绍的这种实现方式还是以后要介绍的command模式,都需要记录这些内容,否则无法还原或者重新实现操作。
今天介绍的保存操作的方式我称之为撒网型保存操作方式,因为是在所有可能出现undo操作的地方都进行记录,然后将所有记录的undo/redo操作都集中在一起进行undo/redo处理,就像是一个人站在原地不停的向各个方向撒网,然后把捞回来的鱼集中处理。
为此,首先定义一个操作记录类,用于保存用户的操作。  
 

public class UserOperationRecord

{

// 记录用户的操作类型

public UserOperationType OptType;

// 用户操作的目标对象的类型,也就是信息编辑界面可能会产生undo/redo信息的类型
public OpeartionTargetType OptTarget;

// 记录用户操作前的数据,由于不同的对象可能信息类型不同,所以类型定义为了object类型
public object DataBeforeOpt;

// 记录用户操作后的数据,由于不同的对象可能信息类型不同,所以类型定义为了object类型
public object DataAfterOpt;

// 辅助信息,用于记录可能需要的信息,比如listbox的SelectIndex
public string AssitantInfo;
}

对每一个OpeartionTargetType都建立一个undoredoManager对象,用于对不同的对象进行不同的undo/redo处理。最后在建立一个总的OptRecordBuffer对象,这个对象的作用如下:1)管理所有目标对象的undoredomanager对象;2)集中保存所有的undo/redo记录,然后统一进行undo/redo操作。具体的内容可以见程序。

Undo/Redo几种实现方式介绍(三)——保存操作方式
该方法最大的问题就是如果存在多类需要处理undo/redo的目标对象,并且每个目标对象需要的辅助信息类型、数量不同,就必须在 UserOperationRecord中把这些信息集中定义在一起,或者 UserOperationRecord类中定义的属性对于不同的目标对象保存不同意义的辅助信息。这样既造成 UserOperationRecord类臃肿,又会影响其他编程人员对程序的理解。

程序代码链接如下,项目文件名为UndoRedoVersion2st.rar: