CN115309476A - 一种基于浏览器的ofd文件显示和编辑方法 - Google Patents

一种基于浏览器的ofd文件显示和编辑方法 Download PDF

Info

Publication number
CN115309476A
CN115309476A CN202211008799.XA CN202211008799A CN115309476A CN 115309476 A CN115309476 A CN 115309476A CN 202211008799 A CN202211008799 A CN 202211008799A CN 115309476 A CN115309476 A CN 115309476A
Authority
CN
China
Prior art keywords
ofd
file
virtual
web
component
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202211008799.XA
Other languages
English (en)
Inventor
许剑锋
周轩
陈轶欧
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Cssca Technologies Co ltd
Original Assignee
Beijing Cssca Technologies Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Cssca Technologies Co ltd filed Critical Beijing Cssca Technologies Co ltd
Priority to CN202211008799.XA priority Critical patent/CN115309476A/zh
Publication of CN115309476A publication Critical patent/CN115309476A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44521Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
    • G06F9/44526Plug-ins; Add-ons
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0484Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces

Abstract

本发明涉及文档编辑技术领域,包括一种基于浏览器的ofd文件显示和编辑方法;首先在浏览器端创建默认虚拟ofd文件,具体按照ofd的文件层次组织结构和数据结构标准,构建由javascript实现的虚拟ofd文件;再根据虚拟ofd文件,创建Web编辑器;通过Web编辑器,选取ofd文件;并进行解析ofd文件;重置虚拟ofd文件;重置编辑器进行编辑ofd文件。本发明根据OFD的文件层次组织结构和数据结构标准,构建由javascript实现的虚拟ofd文件;然后根据虚拟ofd文件,创建Web编辑器;通过Web编辑器,修改虚拟ofd文件;最终实现所见即所得的ofd文件的编辑功能。

Description

一种基于浏览器的ofd文件显示和编辑方法
技术领域
本发明文档编辑技术领域,具体为一种基于浏览器的ofd文件显示和编辑方法。
背景技术
OFD是开放式版式文档,是我国国家标准《GB/T 33190-2016电子文件存储与交换格式版式文档》定义的我国版式文档格式。
所谓“版式文档”,是指它描述的页面内容具有固定的位置、大小、颜色等外观信息,确保页面内容在所有终端的显示效果完全固定、一致。
ofd文件作为一种版式文档,要求显示效果完全固定、一致,导致很多人习惯性的忽略了ofd文件本身的编辑需求,导致现在缺乏一种基于浏览器的所见即所得的编辑ofd文件的方法。
目前,还没有基于浏览器端的ofd编辑器,只有ofd阅读器。
现有的浏览器端的ofd阅读器,都没有编辑功能,只有显示功能,现有的获取新的样式的ofd文件方法,都是基于桌面端应用的,有以下几种:
1.用Word等流式文档编辑生成相应的流式文档后,通过服务器端转化为ofd文件,从而获取新的ofd文档。因为流式文档样式标准与ofd文档的标准不一样,导致转换后的ofd文件在样式上始终有偏差。尤其是ofd文字排版的格式与Word不一样,导致生成的ofd文件文字排版异常。常常同一段的文字内容,会被拆分成很多独立的段落。
另外,例如发票等特殊的排版场景,Word是很难实现的,从而导致ofd文件的发票等的排版,需要手工的解压ofd文件,直接到xml文件中去修改相应的属性,然后再压缩生成ofd才行。非常的不方便。
2、使用其它的桌面端的PDF编辑器,创建PDF文件,然后转化为OFD文件。如福昕PDF编辑器。
针对以上问题,所以就需要一种基于浏览器的ofd文件显示和编辑方法。
发明内容
本发明的目的在于提供一种基于浏览器的ofd文件显示和编辑方法;根据OFD的文件层次组织结构和数据结构标准,构建由javascript实现的虚拟ofd文件;然后根据虚拟ofd文件,创建Web编辑器;通过Web编辑器,修改虚拟ofd文件;最终实现所见即所得的ofd文件的编辑功能。
具体按以下步骤执行;
S1:在浏览器端创建默认虚拟ofd文件,具体按照ofd的文件层次组织结构和数据结构标准,构建由javascript实现的虚拟ofd文件;
S2:根据虚拟ofd文件,创建Web编辑器;
S3:通过Web编辑器,选取ofd文件;
S4:解析ofd文件;
S5:重置虚拟ofd文件;
S6:重置编辑器进行编辑ofd文件。
进一步,在步骤S2中,Web编辑器组件是一个JavaScript的类或对象,可以完整的绑定所有的ofd标准的数据结构,也能绑定上述创建的虚拟ofd文件,以及虚拟ofd文件的各层的对象。
其中Web编辑器包括菜单栏、控制栏、内容区、属性栏等高级组件,这些组件本质上都是由编辑器组件的抽象类创建的具体类。
Web编辑器包括基于编辑器组件的抽象类创建的头部菜单栏、左侧控制栏、文档编辑栏和右侧属性栏高级组件,其中左侧控制栏包括大纲、页面缩略图、模板缩略图和组织结构,文档编辑栏设有包括Web文档组件、Web页面组件、Web图层组件和Web组件组件,其中文档编辑栏的各个层级与ofd文件的各个层级相对应,在创建相应层级的编辑器对象时,将虚拟ofd文件的对应层级的对象作为参数传入Web编辑器的层级组件中。
其中右侧属性栏包括文档属性、页面属性和控件属性;绑定对应虚拟ofd文件层级的属性,进行编辑ofd文件的属性。
在创建相应层级的Web编辑器对象时,将虚拟ofd文件的对应层级的对象作为参数传入Web编辑器的层级组件中。传入虚拟ofd文件的相应层级的对象的同时,将其属性转化为该编辑器对应层级的组件的属性。从而使各层级的Web编辑器组件和ofd文件的文件层次组件结构形成一一对应的映射关系。由于Web的文档编辑区已经绑定了虚拟ofd文件,从而可以直接修改虚拟ofd文件,实现ofd的编辑功能。
进一步,文档编辑区执行渲染方法,生成与ofd文件对应的dom树,把ofd文件内容在浏览器端渲染出来。
进一步,在步骤S6中,在Web编辑器中进行编辑ofd文件,其中文档编辑栏包括Web组件,所述Web组件包括WebDocument组件、WebPage组件、WebLayer组件和WebDocument组件。
进一步,在步骤S3中,选取ofd的文件,具体包括是xml文件和图片、视频、签章和注释的内容的文件,然后在步骤S4中,将ofd文件各层级的xml文件内容解析为符合ofd数据结构标准的格式,导入到对应到ofd虚拟文件的Web编辑器中。
进一步,右侧属性栏包括文档属性、页面属性和控件属性三个层级;分别对应控制到ofd文档、页面、图元三个层次,具体通过设置属性栏组件events,监听浏览器的操作,根据ofd标准将键入的内容添加到对应ofd的对象或属性中。
进一步,在Web编辑器内容区域添加新的控件;创建Web组件的同时,在相应层级的虚拟ofd文件中增加新的ofd图元对象,以而达到在虚拟ofd文件中增加图元对象的目的。
与现有技术相比,本发明的有益效果是:
1、基于ofd标准创建的能够直接生成ofd文件的数据结构,即虚拟ofd文件,基于虚拟dom树创建的Web编辑器组件的数据结构,能够直接在浏览器端渲染,并监听浏览器操作。通过两者的映射关系,最终实现了在浏览器端的ofd文件的编辑功能。
2、在浏览器端选取ofd文件,把ofd文件的内容显示出来,选择相应的控件或配置属性控制项,配合鼠标和键盘进行拖动、拉伸、输入、删除等操作,即可对ofd文件进行所见即所得的编辑,整个过程不需要服务器端的支持。
附图说明
为了更清楚地说明本发明实施方式的技术方案,下面将对实施方式中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1是本发明的方法流程示意图;
图2是本发明的虚拟ofd文件和Web编辑器的映射图;
图3是本发明的虚拟编辑器的组件结构示意图;
图4是本发明的虚拟ofd文件组件结构图。
具体实施方式
为使本发明实施方式的目的、技术方案和优点更加清楚,下面将结合本发明实施方式中的附图,对本发明实施方式中的技术方案进行清楚、完整地描述,显然,所描述的实施方式是本发明一部分实施方式,而不是全部的实施方式。基于本发明中的实施方式,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施方式,都属于本发明保护的范围。因此,以下对在附图中提供的本发明的实施方式的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施方式。基于本发明中的实施方式,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施方式,都属于本发明保护的范围。
请参阅图1-4,一种基于浏览器的ofd文件显示和编辑方法;
包括以下步骤:如图1,
S1:在浏览器端创建默认虚拟ofd文件,具体按照ofd的文件层次组织结构和数据结构标准,构建由javascript实现的虚拟ofd文件;S2:根据虚拟ofd文件,创建Web编辑器;
S3:通过Web编辑器,选取ofd文件;
S4:解析ofd文件;
S5:重置虚拟ofd文件;
S6:重置编辑器进行编辑ofd文件。
本实施例中,在步骤S2中,Web编辑器组件是一个JavaScript的类或对象,可以完整的绑定所有的ofd标准的数据结构,也能绑定上述创建的虚拟ofd文件,以及虚拟ofd文件的各层的对象。
本发明模拟文件层次组织结构和文件数据结构,使用JavaScript实现对应的的虚拟文件夹类和虚拟文件。然后按照OFD的标准组织起来创建虚拟ofd文件。
OFD的文件层次组织结构,基于包含了父节点和子节点的虚拟文件夹的抽象类实现。OFD的虚拟文件的数据结构,基于包含了虚拟文件夹的父节点和符合ofd标准数据结构的子节点组成的虚拟文件的抽象类实现。虚拟ofd文件组件结构如图4。
如图3,其中Web编辑器包括菜单栏、控制栏、内容区、属性栏等高级组件,这些组件本质上都是由编辑器组件的抽象类创建的具体类。
其中控制栏包括大纲、组件结构、页面缩略图、模板缩略图等;分别控制ofd文档的大纲、组织结构、页面树、模板树等。通过设置对应组件的events属性,监听浏览器操作,可以编辑相应的虚拟ofd文件的内容。
编辑器的属性控制栏相关的属性绑定了虚拟ofd文件对应的内容。属性栏包括文档属性、页面属性、控件属性等三个层级;分别控制到ofd文档、页面、图元三个层次。设置属性栏组件events,监听浏览器操作,如键盘输入后,保存时,根据ofd标准将键入的内容添加到对应ofd的对象或属性中。删除时,如果选中了控件,会在编辑器内容区域删除选中的对象。相关编辑操作能同步修改虚拟ofd文件,这样也能实现相应的编辑目的。
Web编辑器包括基于编辑器组件的抽象类创建的头部菜单栏、左侧控制栏、文档编辑栏和右侧属性栏高级组件,其中左侧控制栏包括大纲、页面缩略图、模板缩略图和组织结构,文档编辑栏设有包括Web文档组件、Web页面组件、Web图层组件和Web组件组件,其中文档编辑栏的各个层级与ofd文件的各个层级相对应,在创建相应层级的编辑器对象时,将虚拟ofd文件的对应层级的对象作为参数传入Web编辑器的层级组件中。
其中右侧属性栏包括文档属性、页面属性和控件属性;绑定对应虚拟ofd文件层级的属性,进行编辑ofd文件的属性。
在创建相应层级的Web编辑器对象时,将虚拟ofd文件的对应层级的对象作为参数传入Web编辑器的层级组件中。传入虚拟ofd文件的相应层级的对象的同时,将其属性转化为该编辑器对应层级的组件的属性。从而使各层级的Web编辑器组件和ofd文件的文件层次组件结构形成一一对应的映射关系。其中虚拟ofd文件和Web编辑器的简略映射图,具体如图2,
由于Web的文档编辑区已经绑定了虚拟ofd文件,从而可以直接修改虚拟ofd文件,实现ofd的编辑功能。
在Web编辑器中进行编辑ofd文件,其中文档编辑栏包括Web组件,所述Web组件包括WebDocument组件、WebPage组件、WebLayer组件和WebDocument组件。选中Web组件时,同步能获取到其绑定的虚拟ofd文件的对应层级的对象。通过设置Web组件的events属性,设置组件dom的监听事件,监听浏览器操作,如拖动、拉伸等鼠标操作,可以获取到控件的位置、样式等等信息,将这些信息转化为虚拟ofd文件的对象的属性,虚拟ofd文件就产生了变化,从而能实现相应的编辑目的。
右侧属性栏包括文档属性、页面属性和控件属性三个层级;分别对应控制到ofd文档、页面、图元三个层次,需要新增控件时,具体通过选中某个控件菜单,拖动放入某个页面,即可在页面中新增控件。
设置菜单组件的events属性,监听浏览器操作,编辑器选取菜单后,在编辑器内容区域可以添加新的控件;创建Web组件的同时,会在相应层级的虚拟ofd文件中增加新的ofd图元对象。从而达到在虚拟ofd文件中增加图元对象的目的。
由于Web编辑器各层级组件与虚拟ofd文件的各层级对象有绑定关系,这样通过Web编辑器组件的events属性设置的监听事件,浏览器就能获取到虚拟ofd文件的对应的层级和结构的对象,通过以上操作方式即可对虚拟ofd文件进行相应的编辑。
本实施例中,Web编辑器组件的抽象类的数据结构如下:
自定义的虚拟dom树的实现方式,tagName表示对应的真实dom的标签名称;className表示该组件的具体类名;dom表示该组件的真实dom;childNodes表示该组件的子节点;events表示监听事件;render方法为渲染方法,将组件本身和组件子节点的真实dom渲染出来。当调用render方法时,会以迭代的方式,创建编辑器组件的所有子节点和子节点对应的真实dom节点;setPropObj表示设置属性方法;removePropObj表示移除某个属性的方法;addChild表示添加子节点;removeChild表示移除某节点;
所有编辑器组件都继承以上抽象类。
编辑器组件包括基础组件和高级组件。
基础组件就是基于dom标签创建的组件,其包括html标签组件和SVG标签组件。
其中,html标签包括
div/span/ul/li/button/input/image/table/textareaheading/sel等;
SVG标签包括svg/path/line/rect/ellipse/circle/text/linear-gradient/defs等。在基础组件的基础上,创建编辑器的高级组件。
高级组件基于基础组件创建,同时兼顾ofd标准数据结构。本发明不再有任何基于真实dom的直接操作,所有的操作都是在编辑器组件上进行的。编辑器组件在监听dom操作的同时也能对的ofd数据结构进行操作。由于ofd标准的数据结构和浏览器的dom数据结构是不一致的,如果直接使用浏览器的dom数据结构,则ofd的数据结构中的很多信息是无法完全实现出来的。本发明使用编辑器组件以解决上述问题。本质上,编辑器组件是一个JavaScript的类或对象,可以完整的绑定所有的ofd标准的数据结构,本发明也能绑定上述创建的虚拟ofd文件,以及虚拟ofd文件的各层的对象。
本实施例中,文档编辑区执行渲染方法,生成与ofd文件对应的dom树,把ofd文件内容在浏览器端渲染出来。
本实施例中,在步骤S3中,选取ofd的文件,具体包括是xml文件和图片、视频、签章和注释的内容的文件件,然后在步骤S4中,将ofd文件各层级的xml文件内容解析为符合ofd数据结构标准的格式,导入到对应到ofd虚拟文件的Web编辑器中。
以上所述仅为本发明的优选实施方式而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (8)

1.一种基于浏览器的ofd文件显示和编辑方法,其特征在于,具体按以下步骤执行;
S1:在浏览器端创建默认虚拟ofd文件,具体按照ofd的文件层次组织结构和数据结构标准,构建由javascript实现的虚拟ofd文件;
S2:根据虚拟ofd文件,创建Web编辑器;
S3:通过Web编辑器,选取ofd文件;
S4:解析ofd文件;
S5:重置虚拟ofd文件;
S6:重置编辑器进行编辑ofd文件。
2.根据权利要求1所述的一种基于浏览器的ofd文件显示和编辑方法,其特征在于,在步骤S2中,Web编辑器包括基于编辑器组件的抽象类创建的头部菜单栏、左侧控制栏、文档编辑栏和右侧属性栏高级组件,其中左侧控制栏包括大纲、页面缩略图、模板缩略图和组织结构,文档编辑栏设有包括Web文档组件、Web页面组件、Web图层组件和Web组件组件,其中文档编辑栏的各个层级与ofd文件的各个层级相对应,在创建相应层级的编辑器对象时,将虚拟ofd文件的对应层级的对象作为参数传入Web编辑器的层级组件中。
3.根据权利要求2所述的一种基于浏览器的ofd文件显示和编辑方法,其特征在于,其中右侧属性栏包括文档属性、页面属性和控件属性;绑定对应虚拟ofd文件层级的属性,进行编辑ofd文件的属性。
4.根据权利要求1所述的一种基于浏览器的ofd文件显示和编辑方法,其特征在于,在步骤S4中,文档编辑区执行渲染方法,生成与ofd文件对应的dom树,把ofd文件内容在浏览器端渲染出来。
5.根据权利要求2所述的一种基于浏览器的ofd文件显示和编辑方法,其特征在于,在步骤S6中,在Web编辑器中进行编辑ofd文件,其中文档编辑栏包括Web组件,所述Web组件包括WebDocument组件、WebPage组件、WebLayer组件和WebDocument组件。
6.根据权利要求1所述的一种基于浏览器的ofd文件显示和编辑方法,其特征在于,在步骤S3中,选取ofd的文件,具体包括是xml文件和图片、视频、签章和注释的内容的文件,然后在步骤S4中,将ofd文件各层级的xml文件内容解析为符合ofd数据结构标准的格式,导入到对应到ofd虚拟文件的Web编辑器中。
7.根据权利要求2所述的一种基于浏览器的ofd文件显示和编辑方法,其特征在于,右侧属性栏包括文档属性、页面属性和控件属性三个层级;分别对应控制到ofd文档、页面、图元三个层次,具体通过设置属性栏组件events,监听浏览器的操作,根据ofd标准将键入的内容添加到对应ofd的对象或属性中。
8.根据权利要求2所述的一种基于浏览器的ofd文件显示和编辑方法,其特征在于,在Web编辑器内容区域添加新的控件;创建Web组件的同时,在相应层级的虚拟ofd文件中增加新的ofd图元对象,以而达到在虚拟ofd文件中增加图元对象的目的。
CN202211008799.XA 2022-08-22 2022-08-22 一种基于浏览器的ofd文件显示和编辑方法 Pending CN115309476A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202211008799.XA CN115309476A (zh) 2022-08-22 2022-08-22 一种基于浏览器的ofd文件显示和编辑方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202211008799.XA CN115309476A (zh) 2022-08-22 2022-08-22 一种基于浏览器的ofd文件显示和编辑方法

Publications (1)

Publication Number Publication Date
CN115309476A true CN115309476A (zh) 2022-11-08

Family

ID=83861848

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202211008799.XA Pending CN115309476A (zh) 2022-08-22 2022-08-22 一种基于浏览器的ofd文件显示和编辑方法

Country Status (1)

Country Link
CN (1) CN115309476A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116432617A (zh) * 2023-06-13 2023-07-14 福昕鲲鹏(北京)信息科技有限公司 Ofd文件的合并方法、装置、设备及介质

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116432617A (zh) * 2023-06-13 2023-07-14 福昕鲲鹏(北京)信息科技有限公司 Ofd文件的合并方法、装置、设备及介质

Similar Documents

Publication Publication Date Title
WO2006051715A1 (ja) 文書処理装置及び文書処理方法
EP1393205A2 (en) Improvements relating to developing documents
JPWO2006051975A1 (ja) 文書処理装置
JPWO2006051964A1 (ja) データ処理システム、データ処理方法、及び管理サーバ
WO2006051713A1 (ja) 文書処理装置及び文書処理方法
WO2006051969A1 (ja) 文書処理装置及び文書処理方法
JPWO2006120926A1 (ja) 入力フォーム設計装置および入力フォーム設計方法
WO2006051954A1 (ja) 文書処理装置及び文書処理方法
JPWO2007081017A1 (ja) 文書処理装置
JP4723511B2 (ja) 文書処理装置及び文書処理方法
CN115309476A (zh) 一种基于浏览器的ofd文件显示和编辑方法
WO2006051716A1 (ja) 文書処理装置及び文書処理方法
WO2006051712A1 (ja) 文書処理装置及び文書処理方法
JPWO2006051966A1 (ja) 文書管理装置及び文書管理方法
US8082496B1 (en) Producing a set of operations from an output description
JPWO2007105364A1 (ja) 文書処理装置及び文書処理方法
JPWO2007007529A1 (ja) 文書処理装置および文書処理モジュール
JPWO2006051974A1 (ja) 文書処理装置および文書処理方法
KR102067661B1 (ko) 위젯 저작 시스템 및 방법
WO2006051714A1 (ja) 文書処理装置及び文書処理方法
JPWO2007032460A1 (ja) データ処理装置
JP2007183849A (ja) 文書処理装置
WO2006051717A1 (ja) 文書処理装置及び文書処理方法
JP2008225932A (ja) データ処理装置及びデータ処理方法
JPWO2006051868A1 (ja) 文書処理装置及び文書処理方法

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination