GWT通过JSNI打印Web页面内容

在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();
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值