`
开坦克抢银行
  • 浏览: 1600 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

GWT通过JSNI打印Web页面内容

    博客分类:
  • GWT
gwt 
阅读更多
在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
0
0
分享到:
评论

相关推荐

    GWT-JSNI.pdf

    ### GWT-JSNI 关键知识点解析 ...通过以上内容,我们可以看到 GWT-JSNI 在 GWT 框架中的重要性和具体应用方式。掌握这些知识点有助于开发者更高效地开发基于 GWT 的前端应用程序,并能够更好地集成外部 JavaScript 库。

    gwt-jsni:用于 GWT 项目的 JSNI 实用程序

    gwt-jsni 用于 GWT 项目的 JSNI 实用程序。 用法 将依赖项添加到您的 Maven POM: &lt; groupId&gt;com.bytebybyte.gwt&lt;/ groupId&gt; &lt; artifactId&gt;jsni &lt; version&gt;1.0.0 &lt; scope&gt;provided 和你的 .gwt.xml 文件: ...

    Google Web工具包(GWT)编程手册The Google Web Toolkit (GWT) Programming Cookbook

    Google Web Toolkit(GWT)是一个用于开发和优化复杂浏览器端应用的开源工具集,它允许开发者使用Java语言编写前端代码,然后通过编译器将Java代码转换成兼容各主流浏览器的JavaScript、HTML和CSS。《Google Web工具...

    gwt-2.8.2 SDK 最新下载 google web toolkit

    通过GWT,开发者可以利用强大的Java生态系统,包括丰富的库和开发工具,进行Web应用开发。 **主要组件和功能:** 1. **Java编译器**:GWT的Java编译器将Java源代码转换为高效的JavaScript,这个过程包括优化、代码...

    GWT (GOOGLE WEB TOOLKIT)介绍PPT

    **GWT (Google Web Toolkit)** 是一款由Google开发的开源工具包,专为Java开发者设计,使得他们能够使用Java语言创建高效、动态且交互性强的Ajax应用。GWT通过将Java代码编译成浏览器可执行的JavaScript和HTML,解决...

    GWT(Google Web Toolkit)

    GWT(Google Web Toolkit) 是 Google 最近推出的一个开发 Ajax 应用的框架,它支持用 Java 开发和调试 Ajax 应用,本文主要介绍如何利用 GWT 进行 Ajax 的开发。 GWT特性简介  1.动态,可重用的UI组件  GWT提供的...

    gwt2.0.4+eclipse3.6创建web application project项目后无法运行的原因分析

    同时,Web内容目录、源代码目录以及部署配置也需要正确设置。 3. **浏览器模拟器问题**:GWT项目通常通过内置的模拟器在本地进行预览。如果模拟器设置不正确或版本过旧,可能导致无法运行。确保在Eclipse的GWT偏好...

    GWT入门 GWT中文教程

    GWT,全称为Google Web ...通过深入学习和实践其中的内容,开发者可以有效地掌握GWT技术,开发出高性能、用户体验优秀的Web应用。在实际学习过程中,应结合实际项目需求,理论与实践相结合,以达到最佳的学习效果。

    gwt 练习 gwt学习

    GWT,全称为Google Web Toolkit,是一个开源的Java框架,用于构建高性能、可维护的富互联网应用程序(RIA)。GWT允许开发者使用Java语言编写客户端代码,然后通过编译器将其转换为优化过的JavaScript,以便在各种...

    gwt开发实例实现

    GWT内置了对Ajax的支持,开发者可以通过异步请求来更新页面内容,提升用户体验。 - **Partial Page Rendering**:GWT利用Ajax技术实现部分页面渲染,只更新页面中需要改变的部分,提高响应速度。 - **History框架*...

    Pro web 2.0 application development with GWT

    本书《Pro Web 2.0 Application Development with GWT》由Jeff Dwyer撰写,旨在通过详细的案例分析和技术指南,帮助读者掌握如何使用GWT构建高质量的Web 2.0应用。 #### 二、GWT简介 Google Web Toolkit(简称GWT...

    GWT Demo,GWT学习时的一些小例子

    例如,一个示例可能展示了如何创建一个按钮控件,当用户点击按钮时,通过GWT的RPC机制向服务器发送请求,获取数据并更新页面上的显示。另一个示例可能涉及使用GWT的Composite类来组合多个Widget,创建自定义的复杂...

    GWT

    GWT通过将Java代码编译为JavaScript,使得开发者可以使用Java语言进行客户端的Web开发,从而避免了直接编写JavaScript的复杂性。 GWT的核心特点包括: 1. **Java编程**:GWT允许开发者使用Java语言进行前端开发,...

    使用 GWT 和 RESTful Web 服务构建动态的组织树

    标题中的“使用 GWT 和 RESTful Web 服务构建动态的组织树”暗示了这篇博文将探讨如何使用Google Web Toolkit (GWT) 和RESTful Web服务来创建一个动态展示组织结构的应用程序。GWT是一个用于开发Java web应用的开源...

    GWT(googel web toolkit)api帮助手册

    7. **CSS样式管理**:GWT提供了一套基于Java的CSS样式管理工具,允许开发者通过Java代码控制页面样式。 8. **响应式设计**:GWT提供了`com.google.gwt.user.client.ui.IsWidget`接口,用于实现响应式布局,适应不同...

    gwt技术介绍

    GWT(Google Web Toolkit)是一个开源的Java开发框架,由Google公司开发,...GWT不仅极大地降低了使用Java开发Web客户端应用的门槛,还通过强大的工具链和丰富的类库支持,为开发者提供了完整的开发到部署的解决方案。

    gwt教程

    GWT通过编译Java代码为高效的JavaScript,使得开发者可以充分利用Java的强大功能和生态系统,同时享受到Web开发的便捷性。 ## GWT简介 Google Web Toolkit的核心理念是将Java的生产力引入到Web应用开发中。它提供...

    smartgwt最新版本GWT的DEMO

    SmartGWT是基于Google Web Toolkit (GWT) 的一个开源框架,它为开发富互联网应用程序(RIA)提供了丰富的组件库和高级功能。SmartGWT的最新版本进一步提升了用户体验,简化了开发过程,提供了更多现代Web设计的需求...

Global site tag (gtag.js) - Google Analytics