在GWT中通过JSNI调用JS脚本去执行web页面打印:
首先是预览打印界面,代码如下:
package net.carefx.sde.editor.web.editor.client.partogram;
import net.carefx.component.editor.web.client.jsni.PartogramScript;
import com.extjs.gxt.ui.client.Style.HorizontalAlignment;
import com.extjs.gxt.ui.client.Style.Scroll;
import com.extjs.gxt.ui.client.event.BaseEvent;
import com.extjs.gxt.ui.client.event.ButtonEvent;
import com.extjs.gxt.ui.client.event.Events;
import com.extjs.gxt.ui.client.event.Listener;
import com.extjs.gxt.ui.client.event.SelectionListener;
import com.extjs.gxt.ui.client.widget.Dialog;
import com.extjs.gxt.ui.client.widget.LayoutContainer;
import com.extjs.gxt.ui.client.widget.button.Button;
import com.extjs.gxt.ui.client.widget.layout.FitLayout;
import com.google.gwt.dom.client.Element;
import com.google.gwt.user.client.DOM;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.Image;
/**
* 产程图预览打印窗口
* @author icarefx-lqy
*
*/
public class PartogramPreview extends Dialog
{
//向产程图绘制程序发出请求资源:imgUrl + imgName = 请求地址
// private String imgUrl = "http://localhost:8080/chanchengtu/img?";
private String imgUrl = null;
private String imgName;
private PartogramScript script;
public PartogramPreview (String imgName, String imgUrl)
{
this.imgUrl = imgUrl;
this.imgName = imgName;
script = new PartogramScript();
initUI();
}
private void initUI ()
{
setSize (960, Window.getClientHeight () - 64);
setHeading("产程图预览");
setLayout(new FitLayout());
final LayoutContainer lc = new LayoutContainer();
lc.setId("imgContainner");//set div.id="imgContainner";
Image img = new Image();
img.setUrl(imgUrl+imgName);
lc.add(img);
lc.setScrollMode(Scroll.AUTO);
this.setButtons("");
this.setButtonAlign(HorizontalAlignment.CENTER);
this.add(lc);
Button print = new Button("打印");
print.addSelectionListener(new SelectionListener<ButtonEvent>() {
@Override
public void componentSelected(ButtonEvent ce) {
// TODO 调用打印函数
script.excutePrint(imgUrl+imgName);
}
});
Button cancel = new Button("取消");
cancel.addSelectionListener(new SelectionListener<ButtonEvent>() {
@Override
public void componentSelected(ButtonEvent ce) {
// TODO 关闭预览打印
hide();
}
});
this.addButton(print);
this.addButton(cancel);
}
}
然后是JSNI调用:
package net.carefx.component.editor.web.client.jsni;
/**
* 产程图打印脚本
* @author icarefx-lqy
*
*/
public class PartogramScript {
public PartogramScript()
{}
public native void excutePrint(String id)
/*-{
$wnd._divprint(id);
}-*/;
public native void getElementById (String id)
/*-{
$wnd._getdivbyid(id);
}-*/;
}
JSNI调用的JS脚本:
/**
* 打印DIV包裹的内容
* @param printdiv
* @returns {Boolean}
*/
function _divprint (id)
{
var win = window.open('','','width=925,height=1055');;
var headstr = "<html><head><title></title></head><body>";
var img = "<img src='"+id+"' />";
var footstr = "</body></html>";
win.document.open("text/html","replace");
win.document.writeln(headstr);
win.document.writeln(img);
win.document.write(footstr);
win.document.close();
win.print();
}
- 大小: 18.1 KB
分享到:
相关推荐
### GWT-JSNI 关键知识点解析 ...通过以上内容,我们可以看到 GWT-JSNI 在 GWT 框架中的重要性和具体应用方式。掌握这些知识点有助于开发者更高效地开发基于 GWT 的前端应用程序,并能够更好地集成外部 JavaScript 库。
gwt-jsni 用于 GWT 项目的 JSNI 实用程序。 用法 将依赖项添加到您的 Maven POM: < groupId>com.bytebybyte.gwt</ groupId> < artifactId>jsni < version>1.0.0 < scope>provided 和你的 .gwt.xml 文件: ...
Google Web Toolkit(GWT)是一个用于开发和优化复杂浏览器端应用的开源工具集,它允许开发者使用Java语言编写前端代码,然后通过编译器将Java代码转换成兼容各主流浏览器的JavaScript、HTML和CSS。《Google Web工具...
通过GWT,开发者可以利用强大的Java生态系统,包括丰富的库和开发工具,进行Web应用开发。 **主要组件和功能:** 1. **Java编译器**:GWT的Java编译器将Java源代码转换为高效的JavaScript,这个过程包括优化、代码...
**GWT (Google Web Toolkit)** 是一款由Google开发的开源工具包,专为Java开发者设计,使得他们能够使用Java语言创建高效、动态且交互性强的Ajax应用。GWT通过将Java代码编译成浏览器可执行的JavaScript和HTML,解决...
GWT(Google Web Toolkit) 是 Google 最近推出的一个开发 Ajax 应用的框架,它支持用 Java 开发和调试 Ajax 应用,本文主要介绍如何利用 GWT 进行 Ajax 的开发。 GWT特性简介 1.动态,可重用的UI组件 GWT提供的...
同时,Web内容目录、源代码目录以及部署配置也需要正确设置。 3. **浏览器模拟器问题**:GWT项目通常通过内置的模拟器在本地进行预览。如果模拟器设置不正确或版本过旧,可能导致无法运行。确保在Eclipse的GWT偏好...
GWT,全称为Google Web ...通过深入学习和实践其中的内容,开发者可以有效地掌握GWT技术,开发出高性能、用户体验优秀的Web应用。在实际学习过程中,应结合实际项目需求,理论与实践相结合,以达到最佳的学习效果。
GWT,全称为Google Web Toolkit,是一个开源的Java框架,用于构建高性能、可维护的富互联网应用程序(RIA)。GWT允许开发者使用Java语言编写客户端代码,然后通过编译器将其转换为优化过的JavaScript,以便在各种...
GWT内置了对Ajax的支持,开发者可以通过异步请求来更新页面内容,提升用户体验。 - **Partial Page Rendering**:GWT利用Ajax技术实现部分页面渲染,只更新页面中需要改变的部分,提高响应速度。 - **History框架*...
本书《Pro Web 2.0 Application Development with GWT》由Jeff Dwyer撰写,旨在通过详细的案例分析和技术指南,帮助读者掌握如何使用GWT构建高质量的Web 2.0应用。 #### 二、GWT简介 Google Web Toolkit(简称GWT...
例如,一个示例可能展示了如何创建一个按钮控件,当用户点击按钮时,通过GWT的RPC机制向服务器发送请求,获取数据并更新页面上的显示。另一个示例可能涉及使用GWT的Composite类来组合多个Widget,创建自定义的复杂...
GWT通过将Java代码编译为JavaScript,使得开发者可以使用Java语言进行客户端的Web开发,从而避免了直接编写JavaScript的复杂性。 GWT的核心特点包括: 1. **Java编程**:GWT允许开发者使用Java语言进行前端开发,...
标题中的“使用 GWT 和 RESTful Web 服务构建动态的组织树”暗示了这篇博文将探讨如何使用Google Web Toolkit (GWT) 和RESTful Web服务来创建一个动态展示组织结构的应用程序。GWT是一个用于开发Java web应用的开源...
7. **CSS样式管理**:GWT提供了一套基于Java的CSS样式管理工具,允许开发者通过Java代码控制页面样式。 8. **响应式设计**:GWT提供了`com.google.gwt.user.client.ui.IsWidget`接口,用于实现响应式布局,适应不同...
GWT(Google Web Toolkit)是一个开源的Java开发框架,由Google公司开发,...GWT不仅极大地降低了使用Java开发Web客户端应用的门槛,还通过强大的工具链和丰富的类库支持,为开发者提供了完整的开发到部署的解决方案。
GWT通过编译Java代码为高效的JavaScript,使得开发者可以充分利用Java的强大功能和生态系统,同时享受到Web开发的便捷性。 ## GWT简介 Google Web Toolkit的核心理念是将Java的生产力引入到Web应用开发中。它提供...
SmartGWT是基于Google Web Toolkit (GWT) 的一个开源框架,它为开发富互联网应用程序(RIA)提供了丰富的组件库和高级功能。SmartGWT的最新版本进一步提升了用户体验,简化了开发过程,提供了更多现代Web设计的需求...