- 浏览: 75436 次
- 性别:
- 来自: 深圳
文章分类
最新评论
简单地讲, 一个RCP应用就是一个可独立于Eclispe IDE开发环境运行的Eclipse 插件。
下面我们以一个简单的例子开始我们的RCP旅程。
一、 新建插件工程
因为RCP应用本身就是一个Eclispe插件, 所以从新建一个Eclispe插件工程开始。
1) 启动Eclispe, 从Eclispe的 File菜单创建一个插件工程:
File ->New ->Project ->Plug-in Development ->Plug-in Project
点击Next, 进入New Plug-in Project插件向导:
在Project Name中输入工程名称: simplebrowser (最好小写)。
勾选 “Create an OSGi bundle mainfest” 使用OSGi打包清单。
OSGi是Eclipse 3.0 以上版本用于动态装载插件的标准, 在Eclipse 2.1中是不需要的。最好选中它。
点击Next按钮。
修改Plug-in ID 及其他插件属性值。 这里采用默认值, 在 “Rich Client Application” 一栏中, “Would you like to create a rich client application ?” 一项选择 “Yes” 设置创建的插件为RCP应用。 点击Next。
在模板中选择最基本的Hello RCP 模板, 点击 “Finish” 按钮, Eclispe将会创建一个简单的RCP应用并且自动打开插件清单编辑器的主页面。 在这里你可以方便的配置你的RCP应用, 免去手工编写和修改配置文件的麻烦。
在插件清单编辑器的OverView 页, 点击 “Launch an Eclipse application” 链接就会看到你的RCP应用运行时的样子。
2) 工程创建完成后, Eclipse将自动生成以下内容:
Application类
ApplicationActionBarAdvisor 类
ApplicationWorkbenchAdvisor 类
ApplicationWorkbenchWindowAdvisor类
SimplebrowserPlugin 类
Perspective 类
plugin.xml 文件
build.properties 文件
a) Application类
Application类是RCP应用的主程序, 相当于整个RCP应用的控制器。
Application类的职责是创建一个工作台(Workbench)然后添加一个工作台顾问类(WorkbenchAdvisior)。 它是启动RCP应用运行的第一个程序。
这个类实现了 Eclipse 的 IPlatformRunnable 接口。 对于绝大多数的RCP应用, 这个类的代码都是不用修改的。
工作台(Workbench)是RCP框架的一部分, 一个RCP应用只能有一个工作台, 但是可以有多个工作台窗口(WorkbenchAdvisior)。 工作台的结构如下:
b) Advisor类
ApplicationActionBarAdvisor, ApplicationWorkbenchAdvisor和ApplicationWorkbenchWindowAdvisor
这三个类是 RCP应用的三个核心Advisor类。 它们都继承于相应的抽象Advisor父类。 是RCP应用生命周期中非常重要的三个类。
ApplicationWorkbenchAdvisor
在主程序 Application 类的run() 方法中引用了 ApplicationWorkbenchAdvisor 类。
这个 Workbench Advisor 类对 Workbench 的外观进行了配置。
ApplicationWorkbenchAdvisor 继承了WorkbenchWindowAdvisor 抽象类, 插件工程向导自动填充了createWorkbenchWindowAdvisor和getInitialWindowPerspectiveId方法体, 我们同样可以覆写( override )父类的其他方法。 这个类的方法会在工作台( Workbench )的生命周期的各个关键时刻由RCP平台调用。 是最重要的一个Advisor类。
下面是对Workbench Advisor 类中几个重要的方法的简要说明:
方法
|
说明
|
initialize
|
在启动工作台 ( Workbench ) 前进行初始化。 这个方法有只有一个参数: IWorkbenchConfigurer
|
preStartup
|
在初始化完成之后, 打开第一个窗口之前调用, 在这里可以对打开编辑器和视图的初始化参数进行设置。
|
postStartup
|
在所有窗口打开或恢复以后开始事件循环之前调用。 在这里可以进行一些类似自动批处理的工作。
|
preShutdown
|
在事件循环结束以后, 关闭任何一个窗口之前调用
|
postShutdown
|
在所有窗口关闭之后, 关闭工作台 ( Workbench ) 之前调用, 可以用来保存当前应用的状态, 清理 initialize 方法创建的内容
|
现在我们不需要对这个类进行任何修改。
ApplicationWorkbenchWindowAdvisor
ApplicationWorkbenchWindowAdvisor 继承了WorkbenchWindowAdvisor 类, 这个类主要负责对 Worbench Window 进行控制, 例如状态栏, 工具条, 标题, 窗口尺寸等。
这个类中的方法在 Workbench Window 的生命周期中起着重要作用。
方法
|
说明
|
preWindowOpen
|
在 WorkBench Window 的构造函数中调用, 用于设置窗口的一些特征, 如 是否显示状态栏。 但是这个时候还没有创建任何窗体控件, 所以在这里还不能引用它们。
|
postWindowRestore
|
在窗口恢复到以前保存的状态之后, 打开窗口之前调用这个方法在新建窗口, Workbench第一次运行, 以及没有保存窗口状态的情况下都不会调用。 在这里可以调用IWorkbench.close() 方法关闭Workbench 和所有打开的Workbench Window。
|
postWindowCreate
|
在窗口创建以后, 打开以前调用。 或者是窗口恢复到以前保存的状态后, 在执行postWindowRestore 方法之后调用
|
openIntro
|
Intro就是你第一次打开Eclispe的时候看到的内容, 这个方法的默认的实现是:
如果IWorkbenchPreferences.SHOW_INTRO 属性被设置为True, 那么在第一次打开窗口的时候将会调用这个方法, 在Intro显示过之后该属性将会设置为False。 后来, 只有在WorkbenchConfigurer.getSaveAndRestore() 方法返回True,并且关闭窗口时intro仍然显示的时候才会调用这个方法。
|
postWindowOpen
|
在 Workbench 窗口打开之后调用, 可以在这里开/关(Tweak)窗体控件, 例如设置Title, 改变窗口尺寸等等。
|
preWindowShellClose
|
这个方法在Workbench窗口关闭之前 ( 严格的讲是它的Shell被关闭之前 ) 由关联到这个窗口的ShellListener调用。如果窗口由于其他什么原因已经关闭了, 则不会调用这个方法。
如果这个方法返回false, 那么关闭Shell的请求将会被忽略, 所以, 这个是唯一的一个可以阻止用户关闭窗口行为的地方, 也是提示用户是否保存当前工作和设置的最佳场所。
|
postWindowClose
|
在Workbench窗口关闭之后调用, 这个时候窗口中的控件都已经被清除了。 在这里可以清除由wOpen 方法创建的内容。
|
createWindowContents
|
这个方法用来创建一个窗口的内容,默认的实现添加了一个菜单栏, 一个工具条, 一个状态栏,一个透视图栏, 和一个快速视图栏。 这些控件的可见性可以使用 IWorkbenchWindowConfigurer 中的 setShow* 方法进行设置。
可以通过在子类中覆写( override ) 这个方法来实现自定义
的窗口内容和布局, 但是必须要调用IWorkbenchWindowConfigurer.createPageComposite方法。
这个方法只有一个参数: Shell。
|
createEmptyWindowContents
|
创建并且返回在窗口没有页面显示的时候要显示的控件。如果返回的是Null, 则会使用默认的窗口背景。 覆写这个方法可以实现自定义的窗口背景。 默认的实现是返回 Null 。
这个方法只有一个参数: Composite
|
插件工程向导自动帮我们填充了createActionBarAdvisor 和 preWindowOpen 方法体, 在 preWindowOpen 方法中我们看到向导隐藏了窗口的工具条和状态栏, 并且设置了窗口的大小和标题栏上显示的文字:
public void preWindowOpen() {
IWorkbenchWindowConfigurer configurer = getWindowConfigurer();
configurer.setInitialSize(new Point(400, 300));
configurer.setShowCoolBar(false);
configurer.setShowStatusLine(false);
// 设置窗口标题栏文字
configurer.setTitle("Hello RCP");
}
在这个类的方法中常常需要使用到 Configuer 接口对窗口进行配置, 在方法体中直接调用getWindowConfigurer()方法就可以直接获得IWorkbenchWindowConfigurer对象了, 就像向导在 preWindowOpen() 中所做的一样。
ApplicationActionBarAdvisor
ActionBarAdvisor 类继承了ActionBarAdvisor 类。 这个类负责为Workbench Window 的Action Bar ( 菜单, 工具条和状态栏等 ) 创建Action。 也可以通过插件清单 plugin.xml 文件动态地提供action。
这个类中主要有下面几个方法:
方法
|
说明
|
参数
|
makeActions
|
创建在 fill 方法中使用的 action , 这个方法用来通过 key binding 服务注册 action并且添加到关闭窗口时要清除的 action列表中。
|
IWorkbenchWindow
|
fillMenuBar
|
填充窗口的主菜单
|
IMenuManager
|
fillCoolBar
|
填充窗口的主工具栏
|
ICoolBarManager
|
fillStatusLine
|
填充窗口的主状态栏
|
IStatusLineManager
|
isApplicationMenu
|
这个方法在使用OLE对象做编辑的时候使用,根据传入的菜单ID返回指定的菜单是应用的菜单还是OLE对象的菜单。
在菜单合并期间, 应当保留应用的菜单,至于其他的菜单最好可能从 Window 中删除掉。
|
String
|
现在我们不需要对这个类进行任何修改。
以上列出来的三个 Advisor 类中的方法基本上都是不能够在客户端直接调用的, 而是由 RCP 框架调用的。 关于这一点在相应的 API 文档中有更为详细的说明。
插件工程向导自动为我们实现了Advisor 子类必须实现的各个方法, 根据实际需要我们可以覆写 ( override ) 以上各表中方法来实现我们的意图。 关于这些方法的详细资料请查询相应父类的API文档。
c) SimplebrowserPlugin 类
Plugin类继承了 AbstractUIPlugin 抽象类并且是一个单例 ( singleton ) 类。
这个类提供了对插件 Preferences , dialog store 和 image registry 的支持, 前面两个对象提供了保存插件和对话框设置的有效途径, 后者为整个插件提供了可能在插件中频繁使用的 Image 资源 。 由此可以看出, 这个类主要用来存储插件的全局信息。由于是单例类, 也是放置插件中其他类要用到的静态工具方法的好地方。
现在我们不需要对这个类进行任何修改。
d) Perspective 类
这是RCP应用的默认的透视图。 实现了 IPerspectiveFactory 接口, 并且通过org。eclipse.ui.perspectives 扩展点的className 属性指定。
透视图是一套可见的视图, 编辑器, 和菜单等。 在RCP应用中, 必须定义至少一个透视图并且设置为默认的透视图。
所有启动RCP应用后希望用户看到的视图或编辑器都必须在这个类的createInitialLayout 方法中设置。
e) Plugin.xml 文件
Plugin.xml文件是 Eclipse 的扩展点清单, 这个文件用来定义和使用 Eclipse 扩展点。扩展点是关联 Eclipse 插件的基本方式。 例如, 这里的 Application 类就是通过org.eclipse.core.runtime.applications 扩展点定义的。
Eclipse 提供了插件清单编辑器, 使用这个编辑器可以方便的修改 plugin.xml 文件的内容, 使用这个编辑器可以减少手工编辑这个 xml 文件的工作和错误。 在使用插件向导创建完工程后你看到的就是这个编辑器。
f) build.properties 文件
在导出插件的时候这个文件指定了要build的内容和相关资源的路径。 如果你向应用新增了一些资源, 如图标文件, 要记得把他们添加到 build。properties 文件的bin.include 一节中。
在插件清单编辑器的 Build Configuration 页面可以很方便的在导出应用前对这个文件进行配置。
二、添加视图
基本上Hello RCP模板创建的是一个空的RCP应用, 要实现我们自己的应用界面就需要创建我们自己的视图 (View) 并且添加到当前的透视图中。在这里我们使用了设计器。
1) 创建视图
在这里我们用设计器来创建一个RCP视图:
在Eclispe中打开RCP插件工程, 执行以下操作:
File ->New ->Other ->Designer ->RCP -> ViewPart -> Next
在这里, Name是指视图类的类名, 视图名称是显示在视图标题中的文字, 完成输入后点击 Finish 按钮。 Eclipse将会自动打开BrowserView视图类的源代码视图,点击Design选项卡进入设计器视图。
把 SWT Controls 中的 Browser 控件拖到右边的RCP视图中, 添加Browser控件。
在Property Edtor 中选中 container 在下面的 properites 页中选择 Layout 为GridLayout(AWT), 让浏览器控件自动充满整个视图。
2) 添加视图到当前透视图中
没有添加到透视图中的视图是无法显示的。
打开Perspective类的源代码, 这个类是我们默认的透视图。 在它的createInitialLayout方法中添加以下代码:
layout。addView( BrowserView.ID,
IPageLayout.TOP,
IPageLayout.RATIO_MAX,
IPageLayout.ID_EDITOR_AREA );
把视图添加到当前透视图中。
3) 添加视图的扩展点。
在刚才添加的代码中, layout 的AddView 方法是通过视图的ID ( BrowserView.ID )来找到我们的视图的。 这个ID值存储在于插件清单的Extension 中, Eclipse 正是通过这些扩展点来管理插件的。
在包资源管理器 ( Package Explorer ) 的树形视图中, 双击 plugin.xml 文件打开插件清单编辑器, 点击 Extensions 选项卡打开扩展点清单管理页面:
点击 Add… 按钮打开扩展点选择视图,
在扩展点清单中选中 org.eclipse.ui.views 扩展点, 点击Finish按钮, 回到插件清单编辑器, org.eclipse.ui.views 扩展点已经添加到清单中。
选中刚才添加的 org.eclipse.ui.views 单击鼠标右键, new category 新建一个视图分类, 视图分类是用来分类和组织视图的, 它有三个属性: id ,name 和parentCategory,前两个属性用来唯一标识视图分类, 后一个属性用来组织分类的树型结构。 建议至少为你的视图添加一个分类 ( Category ) 。 这里采用系统默认值。
以用样的方式, 选中刚才添加的 org.eclipse.ui.views 单击鼠标右键, new view 添加视图:
选中刚才添加的视图, 在右边编辑视图扩展点的属性:
在Id一栏填写视图类中的ID值 : simplebrowser.views.BrowserView
( 注: 习惯上, 这个ID值和类的完整包路径是相同的。 )
在Name一栏填写要显示在视图标题栏上的名称 : Simple Browser
在Class 一栏填写视图类(含包路径的完整类名) : simplebrowser.views.BrowserView
在icon 一栏可以指定显示在视图标题栏上的图标 (16X16象素) 。
4) 运行RCP应用
在OverView页面点击 “Launch an Eclipse application” 链接, 你就会看到我们的视图已经显示出来了。
5) 手工添加视图
如果你没有设计器, 也可以通过直接继承 org.eclipse.ui.part.ViewPart 抽象类来创建视图类, 并且使用和上面相同的方法把视图添加到当前透视图中。
6) 使用添加扩展点向导添加视图
用上面的方式添加视图是因为设计器生成的代码比较简洁。其实Eclipse提供了很好的模板和向导来创建和添加视图。
双击Plugin.xml文件打开插件清单编辑器, 点击 Extensions 选项卡, 进入扩展点清单页面:
点击Add… 按钮添加扩展点:
选择 org.eclispe.ui.views 扩展点和Sample View 模板, 点击Next按钮:
勾选 “ Add the view to the resource perspective ” 点击Finish按钮, Eclipse将自动创建视图类并且添加相应的扩展点到插件清单中。
按照前面的方法在 Perspective 类的 createInitialLayout 方法中添加视图到透视图中,启动RCP就会看到新建的视图了。
7) 一点润饰
在插件OverView页面点击 “Lanch an Eclipse application” 会发现透视图下方有一个空的视图区域, 这是EditorArea, 在 Perspective 类的 createInitialLayout 方法中添加layout。setEditorAreaVisible(false); 把它隐藏掉。
现在 Perspective 类的代码变成了这个样子:
public class Perspective implements IPerspectiveFactory {
public void createInitialLayout(IPageLayout layout) {
// 关掉Editor Area ,
// 如果没有用到Editor的话, 请执行这一句
// 否则在透视图中会有一片空白。
layout。setEditorAreaVisible(false);
// 添加Browser视图
layout。addView( BrowserView。ID,
IPageLayout.TOP,
IPageLayout.RATIO_MAX,
IPageLayout.ID_EDITOR_AREA );
// 添加SampleView视图
/*
Layout.addView( "simplebrowser.views.SampleView",
IPageLayout.TOP,
IPageLayout.RATIO_MAX,
IPageLayout.ID_EDITOR_AREA );
*/
}
}
现在RCP打开的窗口的标题还是 “Hello RCP”,在ApplicationWorkbenchWindowAdvisor 类的preWindowOpen() 方法中修改它,并且覆写父类的postWindowCreate() 方法在应用启动后让窗口自动最大化:
代码如下:
/**
* 这个方法将在Workbench Window的构造函数中调用,
* 可用来在创建窗口前设置窗口的选项:
* 例如: 是否含有菜单栏, 状态栏等。
*/
public void preWindowOpen() {
IWorkbenchWindowConfigurer configurer = getWindowConfigurer();
configurer.setInitialSize(new Point(400, 300));
configurer.setShowCoolBar(false);
configurer.setShowStatusLine(false);
// 设置窗口标题栏文字
configurer.setTitle("Simple Browser");
}
/**
* 这个方法在窗口恢复到以前保存的状态(或者新建一个窗口)之后,
* 打开窗口之前(调用)。
*/
public void postWindowCreate() {
super。postWindowCreate();
//设置打开时最大化窗口
getWindowConfigurer().getWindow().getShell().setMaximized(true);
}
co
发表评论
-
EditorPart
2011-04-13 16:26 9791、设置editor标题 @Override publi ... -
RCP控制View 特性配置(如移动、最大化、最小化、关闭等)
2011-03-26 17:34 46821、我们可以添加org.eclipse.ui.perspect ... -
RCP 程序类
2011-03-07 10:21 8791、ApplicationWorkbenchAdvisor ... -
RCP掌握技术
2011-01-13 11:16 963RCP Application Plugin JFac ... -
GMF学习纪要
2010-12-20 15:23 1264创建GEF工程,具体创建步骤可以参考http://www.ib ... -
重命名Action
2010-12-17 10:22 848File selected_file = (File) sel ... -
控制只能开启一个rcp应用程序
2010-11-25 15:22 854private boolean isAreadyRun ... -
开发环境
2010-05-17 16:39 0http://download.eclipse.org/rel ... -
插件国际化
2010-02-09 14:39 1046第三方国际化插件工具 1.sourceforge.net ... -
在透视图显示工作台视图
2010-02-09 09:16 908public class Perspective implem ... -
preWindowOpen 设置样式
2010-01-14 17:08 1394public void preWindowOpen() { ... -
TableViewer, TreeViewer双击编辑
2009-11-05 23:15 3275在TreeViewer或TableViewer中 ... -
RCP 动态 改变 主窗体标题
2009-10-31 09:23 1142在视图或编辑器触发事件中 IWorkbenchWind ... -
Java: applet+jfreechart动态显示方法的执行时间
2009-10-18 23:03 2655public ActionForward execute(Ac ... -
JFreechart综合
2009-10-13 23:13 4599JFreeChart是一个Java开源项目,是一款优秀的J ... -
jfreechart1
2009-08-23 22:54 0? 一、JFreeChart的介绍与获取 JFre ... -
eclispe RCP 小技巧(转)
2009-08-05 22:58 2991一、同时关闭所有打开的view 在view中,只有一个clo ... -
初学RCP开发
2009-07-28 09:37 14291、以前用过AWT,对SWT掌握不难! 2、必须掌握3个概念 ... -
PreferencePage自定义运行时空指针异常疑惑
2009-07-27 16:19 1135PreferenceManager mgr = new P ...
相关推荐
Eclipse Rich Client Platform (RCP) 是一个强大的框架,用于构建桌面应用程序。它提供了一整套工具和功能,使得开发者可以构建出具有丰富用户界面的应用。在开发完成后,我们需要将这些应用打包并发布,以便用户...
Eclipse RCP,全称Eclipse Rich Client Platform,是一个基于Java的框架,用于构建桌面应用程序。这个框架由Eclipse基金会维护,是Eclipse IDE的一部分,允许开发者创建功能丰富的、可扩展的应用程序,拥有类似IDE的...
Eclipse RCP,全称Eclipse Rich Client Platform,是一种基于Java的开源框架,用于构建桌面应用程序。它由Eclipse基金会维护,是Eclipse IDE的核心组成部分,提供了丰富的UI组件、插件系统以及工作台(Workbench)...
Eclipse RCP 教程 Eclipse RCP(Rich Client Platform)是一种基于 Eclipse 平台的客户端开发技术,能够帮助开发者快速构建功能强大且界面美观的桌面应用程序。在本教程中,我们将详细介绍 Eclipse RCP 的开发过程...
### Eclipse RCP 入门详解 #### 一、Eclipse RCP 概述 **Eclipse RCP**(Rich Client Platform)是一种构建丰富客户端应用程序的框架,它利用Eclipse平台的强大功能来创建高度定制化的桌面应用程序。通过RCP,...
【标题】"eclipse RCP mp3工程"指的是一个基于Eclipse Rich Client Platform(RCP)构建的专门处理MP3音频文件的应用程序。Eclipse RCP是一个强大的开发框架,允许开发者创建桌面应用,它提供了丰富的用户界面组件和...
Eclipse RCP是一种基于Eclipse平台的富客户端平台技术,它允许开发者创建独立于Eclipse环境的Java桌面应用程序。RCP通过提供一套标准组件和API,简化了桌面应用程序的开发流程,使开发者能够专注于业务逻辑而非界面...
eclipse RCP Plug-in开发自学教程 eclipse RCP(Rich Client Platform)是一种基于eclipse的插件式开发平台,允许开发者使用eclipse结构风格设计弹性的可扩展的应用程序。RCP插件式开发方式可以重用eclipse中的方法...
《ECLIPSE+RCP应用系统开发方法与实战》这本书是高岗先生关于使用Eclipse RCP(Rich Client Platform)进行应用系统开发的一本实战指南。Eclipse RCP是Eclipse IDE的一部分,它提供了一个框架,使得开发者可以构建...
Eclipse RCP(Rich Client Platform)是一个开源框架,由Eclipse基金会开发,用于构建桌面应用程序。这个框架基于Java,提供了一套完整的工具集,包括插件系统、工作台管理、视图、编辑器、透视图等,使得开发者可以...
Eclipse Rich Client Platform(RCP)是Eclipse框架下的一个核心组成部分,用于构建桌面应用程序。这个"Eclipse RCP培训.zip"文件很可能包含了关于如何开发基于Eclipse RCP的应用程序的各种教程、示例代码和讲解材料...
《Eclipse RCP与Spring OSGi:技术详解与最佳实践》由资源的Eclipse专家亲自执笔,并得到了Eclipse官方技术社区的强烈推荐,权威性毋庸置疑!内容全面,系统讲解了利用Eclipse RCP和Spring OSGi开发大规模Java应用的...
### Eclipse RCP 插件开发指南 #### Eclipse RCP Plugin 开发快速入门 Eclipse RCP(Rich Client Platform)插件开发是构建基于Eclipse框架的应用程序的核心技术之一。本指南旨在帮助开发者从零开始掌握Eclipse ...
总之,这个“eclipse rcp excel表转mysql程序”项目结合了Eclipse RCP的桌面应用开发能力、Apache POI的Excel处理功能以及JDBC的数据库操作,实现了从Excel数据到MySQL数据库的自动化转换。开发者可以通过学习和理解...
Eclipse Rich Client Platform (RCP) 是一个强大的框架,用于构建桌面应用程序。它基于Java,由Eclipse基金会维护,是Eclipse IDE的核心组成部分。RCP允许开发者利用已有的插件系统构建可定制、模块化的应用,具有...
Eclipse Rich Client Platform (RCP) 是一个强大的框架,用于构建桌面应用程序,它基于Java语言并利用了Eclipse IDE的核心技术。Eclipse RCP允许开发者创建功能丰富的、可扩展的应用程序,这些应用程序拥有与Eclipse...
在IT行业中,Eclipse RCP(Rich Client Platform)是一个强大的框架,用于构建桌面应用程序。它基于Java语言,由Eclipse基金会开发,为开发者提供了一套完整的工具集来创建功能丰富的、可扩展的应用程序。"菜鸟...
### Eclipse RCP 详细教程 #### 1. 富客户端平台 ##### 1.1. 概述 Eclipse RCP(Rich Client Platform)是一种基于Java的框架,它允许开发者构建高度可定制和可扩展的桌面应用。这些应用通常具有丰富的用户界面,...
Eclipse RCP(Rich Client Platform)是一个开源框架,用于构建桌面应用程序。Common Navigator是Eclipse RCP中的一个重要组件,它提供了一种通用的资源浏览和管理界面。在本"Common Navigator demo"中,我们将深入...