可打印组件 : 打印 « 图形用户界面 « Java

En
Java
1. 图形用户界面
2. 三维图形动画
3. 高级图形
4. 蚂蚁编译
5. Apache类库
6. 统计图
7. 
8. 集合数据结构
9. 数据类型
10. 数据库JDBC
11. 设计模式
12. 开发相关类
13. EJB3
14. 电子邮件
15. 事件
16. 文件输入输出
17. 游戏
18. 泛型
19. GWT
20. Hibernate
21. 本地化
22. J2EE平台
23. 基于J2ME
24. JDK-6
25. JNDI的LDAP
26. JPA
27. JSP技术
28. JSTL
29. 语言基础知识
30. 网络协议
31. PDF格式RTF格式
32. 映射
33. 常规表达式
34. 脚本
35. 安全
36. Servlets
37. Spring
38. Swing组件
39. 图形用户界面
40. SWT-JFace-Eclipse
41. 线程
42. 应用程序
43. Velocity
44. Web服务SOA
45. 可扩展标记语言
Java 教程
Java » 图形用户界面 » 打印屏幕截图 
可打印组件
  

/*
 * This example is from the book "Java Foundation Classes in a Nutshell".
 * Written by David Flanagan. Copyright (c) 1999 by O'Reilly & Associates.  
 * You may distribute this source code for non-commercial purposes only.
 * You may study, modify, and use this example for any purpose, as long as
 * this notice is retained.  Note that this example is provided "as is",
 * WITHOUT WARRANTY of any kind either expressed or implied.
 */

import java.awt.*;
import java.awt.print.*;

/**
 * This wrapper class encapsulates a Component and allows it to be printed
 * using the Java 2 printing API.
 */
public class PrintableComponent implements Printable {
  // The component to be printed.
  Component c;

  /** Create a PrintableComponent wrapper around a Component */
  public PrintableComponent(Component c) { this.c = c; }

  /**
   * This method is not part of the Printable interface.  It is a method
   * that sets up the PrinterJob and initiates the printing.
   */
  public void print() throws PrinterException {
    // Get the PrinterJob object
    PrinterJob job = PrinterJob.getPrinterJob();
    // Get the default page format, then allow the user to modify it
    PageFormat format = job.pageDialog(job.defaultPage());
    // Tell the PrinterJob what to print
    job.setPrintable(this, format);
    // Ask the user to confirm, and then begin the printing process
    if (job.printDialog()) 
      job.print();
  }

  /**
   * This is the "callback" method that the PrinterJob will invoke.
   * This method is defined by the Printable interface.
   */
  public int print(Graphics g, PageFormat format, int pagenum) {
    // The PrinterJob will keep trying to print pages until we return
    // this value to tell it that it has reached the end.
    if (pagenum > 0
      return Printable.NO_SUCH_PAGE;

    // We're passed a Graphics object, but it can always be cast to Graphics2D
    Graphics2D g2 = (Graphics2Dg;

    // Use the top and left margins specified in the PageFormat Note
    // that the PageFormat methods are poorly named.  They specify
    // margins, not the actual imageable area of the printer.
    g2.translate(format.getImageableX(), format.getImageableY());

    // Tell the component to draw itself to the printer by passing in 
    // the Graphics2D object.  This will not work well if the component
    // has double-buffering enabled.
    c.paint(g2);

    // Return this constant to tell the PrinterJob that we printed the page.
    return Printable.PAGE_EXISTS;
  }
}


           
         
    
  
Related examples in the same category
1. 印刷代码实现打印
2. 打印图像直接打印
3. 最简单的SWT打印范例最简单的SWT打印范例
4. 打印在Java 2 : PrinterJob
5. 打印在Java :网页格式和文件
6. 打印在Java :多页
7. 打印在Java 5
8. 打印在Java 6
9. 简单的图书印刷简单的图书印刷
10. 形状打印形状打印
11. 显示打印对话框并打印
12. 打印打印区域概述打印打印区域概述
13. 打印的文本文件和打印预览打印的文本文件和打印预览
14. 可打印演示可打印演示
15. 打印图形界面组件打印图形界面组件
16. 书
17. 另一个打印演示另一个打印演示
18. 图书打印演示图书打印演示
19. 印刷组合Java 1.2和1.4之路印刷组合Java 1.2和1.4之路
20. 印刷方式Java 1.4
21. 提示打印机
22. 印刷方式Java 1.1印刷方式Java 1.1
23. 涂鸦涂鸦
24. 可打印文件
25. PrintFile -打印文件命名的命令行PrintFile -打印文件命名的命令行
26. 打印到标准输出
27. PrintPanel is the base for an open-ended series of classesPrintPanel is the base for an open-ended series of classes
28. 打印演示:图书打印演示:图书
29. Print Test Print Test
30. 分页文字分页文字
31. 可打印区域
32. 实际可打印区域
33. 打印页的不同格式
34. 设置定位的打印页面
35. 打印对话框:更改默认打印机设置(默认打印机,份数,范围页)
36. 打印到文件
37. 监听打印服务状态变化
38. 打印图片
39. 覆盖的默认操作的JTextComponent
40. 显示页面格式对话框:修改默认的页面格式,如方向和纸张大小。
www.java2java.com | Contact Us
Copyright 2010 - 2030 Java Source and Support. All rights reserved.
All other trademarks are property of their respective owners.