java rcp 视图 通讯_关于java:在Eclipse RCP中显示视图时传递参数

我正在创建Eclipse RCP应用程序,并且在显示视图时遇到传递参数的问题。

作为第一种方法,我尝试在View1的View2中设置静态变量,然后打开该视图(如下所示)。有用。

IWorkbenchPage activePage = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getActivePage();

String viewIdToClose = studentListView.ID;

IViewPart viewToClose = activePage.findView(viewIdToClose);

TableItem item = studentTable.getItem(studentTable.getSelectionIndex());

String text = item.getText(ListViewConstants.TABLE_COLUMN_ONE);

activePage.hideView(viewToClose);

try {

String viewIdToOpen = StudentReview.ID;

StudentReview.userId = text;

activePage.showView(viewIdToOpen);

} catch (PartInitException e) {...}

由于这似乎不是一个好方法,因此我按照以下链接中提到的建议进行了尝试(可接受的答案)。

将参数传递给视图

。在这种方法中,我们只有在显示视图后才能传递参数。

但是我有一个问题是,要打开的视图在调用showView()时应该具有所选行中的值,即我想根据视图1的选择填充视图2中的参数。

有什么办法可以做到这一点?使用PULL代替PUSH方法好吗?

任何建议表示赞赏。

谢谢!!!

更新1:

将参数传递给视图中提到的方法

接口:

public interface ICommunicationView extends IViewPart{

public void accept(Object parameter);

}

调用accept():

IWorkbenchPage activePage = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getActivePage();

String viewIdToClose = StudentListView.ID;

IViewPart viewToClose = activePage.findView(viewIdToClose);

TableItem item = studentTable.getItem(studentTable.getSelectionIndex());

String text = item.getText(ListViewConstants.TABLE_COLUMN_ONE);

activePage.hideView(viewToClose);

try {

String viewIdToOpen = StudentReview.ID;

ICommunicationView viewToOpen = (ICommunicationView) activePage.showView(viewIdToOpen);

viewToOpen.accept(text);//Sending userId to Review view

} catch (PartInitException e) { ... }

StudentReviewView:

private String studentId;

//getters and setters

@Override

public void accept(Object parameter) {

setStudentId(parameter.toString());

}

public void createPartControl(final Composite parent) {

...

System.out.println("Student Id" + this.getStudentId());

}

它将学生ID打印为null。

我是否缺少明显的东西?

谢谢!

为什么您提到的链接上接受的答案不能解决您的问题? 如果在调用showView之后将userId发送到StudentReviewView,它将在打开后立即填充,不是吗?

实际上,我将学生数据存储在名称为.xml的XML文件中。 在审阅视图的createPartControl()中,我将解组相应的XML文件并填充组件。 为此,我在调用createPartControl()时需要有StudentId。 在这种情况下,我将学生ID设置为null,因为在发送学生ID之前调用了createPartControl()。 我已经更新了我的问题。 PS:我已经将变量名从userId更改为StudentId。

这是个不错的链接,试试看。

感谢您的链接。 它有很多有用的信息。 不幸的是,由于我没有使用E4,因此上述方法不能满足我的要求。 另外我不确定是否可以使用事件处理机制,因为在显示它之前View2需要该值。

当activePage.showView(viewIdToOpen)打开视图时,平台调用createPartControl。 因此,请勿在createPartControl上填充字段。 调用setStudentId时执行此操作。

谢谢。 将尝试这种方法。

我也遇到了这个问题。 通过重新打包需要更新的特定视图组件,找到了解决之道。

这是设置字符串的概念证明:

设置器界面:

public interface ViewSetter {

void setMessage(String message);

}

已初始化的视图:

//view that implements ViewSetter

@Override

public void createPartControl(Composite parent) {

label = new Label(parent, SWT.NONE); //label is a field

}

@Override

public void setMessage(final String message) {

Display.getDefault().syncExec(new Runnable() {

@Override

public void run() {

label.setText(message);

label.pack(true);

}

});

}

创建和初始化视图的代码:

IViewPart view = page.showView(viewID);

ViewSetter viewSetter = (ViewSetter)view;

viewSetter.setMessage("Hello World");

框架特点: 1.完善的企业应用解决方案,包括表现层,业务逻辑层,报表,权限,日志,国际化,部署等企业应用的各个环节。 2.B/S,C/S优势互补,随需应变。 3.全新的模式开发C/S客户端,无需布局,无需调整控件和组件的大小,不懂Swing也可以快速开发界面。 4.Spring+Hibernate的轻量级架构轻松开发业务逻辑。 5.提升用户体验,提高最终用户满意度,快速开发企业应用。 配置开发环境 1导入开发项目 下载(http://www.soyframework.com)已经配置好的空项目,此空项目包括empty-client (以下简称示例client项目)、empty-server (以下简称示例server项目),并将它们导入到Eclipse。如果Eclipse的Problems标签下没有出现错误那么表示项目成功导入。 如果使用其他的集成开发环境,请将client和server分别配置成java项目,且client依赖server。 2.1.2创建数据库 用户需要在自己的数据库管理系统创建一个数据库,并确保此数据库实例能正常运行。示例项目使用的数据库为MYSQL,假定我们在MYSQL创建数据库empty,并且创建用户empty,将数据库empty的所有权限授予给用户empty。 2.1.3配置hibernate 打开server项目下的hibernate.properties 文件,修改Hibernate数据库方言的配置(hibernate.dialect)为项目选用的数据库类型,如果采用是mysql 5.0数据库,设置为org.hibernate.dialect.MySQLDialect, 如果采用oracle9+数据库则设置为org.hibernate.dialect.Oracle9Dialect,如果是其他数据库请参考hibernate数据库方言。示例项目使用Mysql,故配置方言为org.hibernate.dialect.MySQLDialect。 打开server项目下的dataSourceConfig.xml文件,根据具体使用的数据库配置数据库连接池,下面列出了选用的数据库为Mysql,连接池的配置: <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName"> <value>com.mysql.jdbc.Driver</value> </property> <property name="url"> <value>jdbc:mysql://${database.host}:${database.port}/empty?autoReconnect=true&useUnicode=true&characterEncoding=utf-8</value> </property> <property name="username"> <value>empty</value> </property> <property name="password"> <value>empty</value> </property> </bean> 在dataSourceConfig.properties配置数据库服务器的主机地址和端口: database.host=localhost database.port=3306 2.1.4运行项目 开发使用的应用服务器为Jetty,Server项目下的JettyLauncher.java已经配置了一个Jetty服务器,应用名默认为empty,端口使用8888(用户可以根据实际情况自行修改)。将JettyLauncher作为java application运行,启动服务器,如不出现异常,则server项目配置成功。 打开client项目下的ApplicationLauncher.java文件,作为java application 运行,启动客户端。如果出现设置管理员界面,则client项目配置成功。设置管理员后在用户登录界面以管理员身份登录后即出现系统主界面。 转http://hi.csdn.net/mysoy
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值