java根据url生成网页截图,缩略图

源地址:http://blog.csdn.net/cping1982/article/details/5353049

public class ShotsPic extends JPanel {

private static final long serialVersionUID = 1L;

// 行分隔符
final static public String LS = System.getProperty("line.separator", "\n");

// 文件分割符
final static public String FS = System.getProperty("file.separator", "\\");

//以javascript脚本获得网页全屏后大小
final static StringBuffer jsDimension;

static {
jsDimension = new StringBuffer();
jsDimension.append("var width = 0;").append(LS);
jsDimension.append("var height = 0;").append(LS);
jsDimension.append("if(document.documentElement) {").append(LS);
jsDimension.append("  width = Math.max(width, document.documentElement.scrollWidth);").append(LS);
jsDimension.append("  height = Math.max(height, document.documentElement.scrollHeight);").append(LS);
jsDimension.append("}").append(LS);
jsDimension.append("if(self.innerWidth) {").append(LS);
jsDimension.append("  width = Math.max(width, self.innerWidth);").append(LS);
jsDimension.append("  height = Math.max(height, self.innerHeight);").append(LS);
jsDimension.append("}").append(LS);
jsDimension.append("if(document.body.scrollWidth) {").append(LS);
jsDimension.append("  width = Math.max(width, document.body.scrollWidth);").append(LS);
jsDimension.append("  height = Math.max(height, document.body.scrollHeight);").append(LS);
jsDimension.append("}").append(LS);
jsDimension.append("return width + ':' + height;");
}


public ShotsPic( String url) {
super(new BorderLayout());
JPanel webBrowserPanel = new JPanel(new BorderLayout());
final String fileName = "screenShots.jpg";
final JWebBrowser webBrowser = new JWebBrowser(null);
webBrowser.setBarsVisible(false);
webBrowser.navigate(url);
webBrowserPanel.add(webBrowser, BorderLayout.CENTER);
add(webBrowserPanel, BorderLayout.CENTER);


JPanel panel = new JPanel(new FlowLayout(FlowLayout.CENTER, 4, 4));


webBrowser.addWebBrowserListener(new WebBrowserAdapter() {


// 监听加载进度
public void loadingProgressChanged(WebBrowserEvent e) {
// 当加载完毕时
if (e.getWebBrowser().getLoadingProgress() == 100) {

//动态执行JS 最终返回网页的实际的宽度和高度
String result = (String) webBrowser.executeJavascriptWithResult(jsDimension.toString());

System.out.println(result);

int index = result == null ? -1 : result.indexOf(":");
NativeComponent nativeComponent = webBrowser.getNativeComponent();
Dimension originalSize = nativeComponent.getSize();
Dimension imageSize = new Dimension(Integer.parseInt(result.substring(0, index)), Integer.parseInt(result.substring(index + 1)));

imageSize.width = Math.max(originalSize.width,imageSize.width);
imageSize.height = Math.max(originalSize.height,imageSize.height);

System.out.println(imageSize.width);
System.out.println(imageSize.height);


nativeComponent.setSize(imageSize);
BufferedImage image = new BufferedImage(imageSize.width,imageSize.height, BufferedImage.TYPE_INT_RGB);
nativeComponent.paintComponent(image);

//nativeComponent.setSize(imageSize);
// 当网页超出目标大小时

/*if (imageSize.width > maxWidth|| imageSize.height > maxHeight) {
//截图部分图形
image = image.getSubimage(0, 0, maxWidth, maxHeight);
}*/

/*//此部分为使用缩略图
int width = image.getWidth(), height = image
.getHeight();
AffineTransform tx = new AffineTransform();
tx.scale((double) maxWidth / width, (double) maxHeight
/ height);
AffineTransformOp op = new AffineTransformOp(tx,
AffineTransformOp.TYPE_NEAREST_NEIGHBOR);
//缩小
image = op.filter(image, null);
*/
try {
// 输出图像
ImageIO.write(image, "jpg", new File("E:\\"+fileName));
} catch (IOException ex) {
ex.printStackTrace();
}
// 退出操作
System.exit(0);
}
}
}


);
add(panel, BorderLayout.SOUTH);


}


public static void main(String[] args) {
NativeInterface.open();
SwingUtilities.invokeLater(new Runnable() {
public void run() {

JFrame frame = new JFrame("以DJ组件保存指定网页截图");

frame.getContentPane().add(
new ShotsPic("www.qq.com"),
BorderLayout.CENTER);
frame.setSize(1280, 768);
// 仅初始化,但不显示
frame.invalidate();
frame.pack();
frame.setVisible(false);
}
});
NativeInterface.runEventPump();
}

}

程序需要三个包:,下载地址请参考原文地址!

注:如果网速不是很好,会对截图有一定的影响!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值