Skip to content

Latest commit

 

History

History
106 lines (75 loc) · 7.54 KB

File metadata and controls

106 lines (75 loc) · 7.54 KB

打印HTML文档

编写:jdneo - 原文:http://developer.android.com/training/printing/html-docs.html

在Android上要打印比一副照片更丰富的内容,换句话说,若需要将文本和图片组合在一个打印的文档中。Android框架提供了一种使用HTML语言来组织一个文档并打印的方法,它使用的代码数量是很小的。

WebView类在Android 4.4(API Level 19)中得到了更新,使得它可以打印HTML内容。这个类允许你加载一个本地的HTML资源或者从一个网页下载一个页面,创建一个打印任务,并把它交给Android打印服务。

这节课将向您展示如何快速地构建一个HTML文档,它包含文本和图片,并使用WebView来打印它。

加载一个HTML文档

WebView打印一个HTML文档,会涉及到加载一个HTML资源,或者以String的形式构建一个HTML文档。这一节将描述如何构建一个HTML的字符串并将它加载到WebView中,以备打印。

这个View对象一般被用来作为一个activity布局的一部分。然而,如果你的应用不使用WebView,你可以创建一个该类的实例,以进行打印。创建该自定义打印界面的主要步骤是:

  1. 在HTML资源加载完毕后,创建一个WebViewClient用来启动一个打印任务。
  2. 加载HTML资源至WebView对象。

下面的代码展示了如何创建一个简单的WebViewClient并且加载一个动态创建的HTML文档:

private WebView mWebView;

private void doWebViewPrint() {
    // Create a WebView object specifically for printing
    WebView webView = new WebView(getActivity());
    webView.setWebViewClient(new WebViewClient() {

            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                return false;
            }

            @Override
            public void onPageFinished(WebView view, String url) {
                Log.i(TAG, "page finished loading " + url);
                createWebPrintJob(view);
                mWebView = null;
            }
    });

    // Generate an HTML document on the fly:
    String htmlDocument = "<html><body><h1>Test Content</h1><p>Testing, " +
            "testing, testing...</p></body></html>";
    webView.loadDataWithBaseURL(null, htmlDocument, "text/HTML", "UTF-8", null);

    // Keep a reference to WebView object until you pass the PrintDocumentAdapter
    // to the PrintManager
    mWebView = webView;
}

Note: 确保你所调用的生成打印的任务发生在之前那一节所创建的[WebViewClient](http://developer.android.com/reference/android/webkit/WebViewClient.html#onPageFinished(android.webkit.WebView, java.lang.String))中的[onPageFinished()](http://developer.android.com/reference/android/webkit/WebViewClient.html#onPageFinished\(android.webkit.WebView, java.lang.String))方法内。如果你不等待页面加载完毕后再打印,打印的输出可能会不完整或空白,甚至可能会失败。

**Note:**上面的样例代码维护了一个WebView对象实例,这样就保证了它不会在打印任务创建之前就被垃圾回收器所回收。请确保你在你的实现中也同样这么做,否则打印的进程可能会无法继续执行。

如果你希望页面中包含图像,将这个图像文件放置在你的工程的“assets/”目录,并指定一个基URL,作为[loadDataWithBaseURL()](http://developer.android.com/reference/android/webkit/WebView.html#loadDataWithBaseURL\(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String))方法的第一个参数,就像下面所显示的一样:

webView.loadDataWithBaseURL("file:///android_asset/images/", htmlBody,
        "text/HTML", "UTF-8", null);

你也可以加载一个网页来打印,方法是将[loadDataWithBaseURL()](http://developer.android.com/reference/android/webkit/WebView.html#loadDataWithBaseURL\(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String))方法替换为loadUrl(),如下所示:

// Print an existing web page (remember to request INTERNET permission!):
webView.loadUrl("http://developer.android.com/about/index.html");

当使用WebView来创建一个打印文档时,你要注意下面的一些限制:

  • 你不能为文档添加页眉和页脚,包括页号。
  • HTML文档的打印选项不包含选择打印的页数范围,例如:对于一个10页的HTMl文档,只打印2到4页是不可以的。
  • 一个WebView的实例只能在同一时间处理一个打印任务。
  • 若一个HTML文档包含CSS打印属性,比如一个landscape属性,是不支持的。
  • 你不能通过一个HTML文档中的JavaScript脚本来激活打印。

**Note:**一旦在布局中包含的WebView对象加载好了文档,就可以打印WebView对象的内容。

如果你希望创建一个更加自定义化的打印输出并希望可以完全控制打印页面上绘制的内容,可以学习下一节课程:打印自定义文档

创建一个打印任务

在创建了WebView并加载了你的HTML内容之后,你的应用就基本完成了打印进程中,属于它的任务。下一步是访问PrintManager,创建一个打印适配器,并在最后,创建一个打印任务。下面的代码展示了如何执行这些步骤:

private void createWebPrintJob(WebView webView) {

    // Get a PrintManager instance
    PrintManager printManager = (PrintManager) getActivity()
            .getSystemService(Context.PRINT_SERVICE);

    // Get a print adapter instance
    PrintDocumentAdapter printAdapter = webView.createPrintDocumentAdapter();

    // Create a print job with name and adapter instance
    String jobName = getString(R.string.app_name) + " Document";
    PrintJob printJob = printManager.print(jobName, printAdapter,
            new PrintAttributes.Builder().build());

    // Save the job object for later status checking
    mPrintJobs.add(printJob);
}

这个例子保存了应用使用的PrintJob对象的实例,这是不必须的。你的应用可以使用这个对象来跟踪打印任务执行时的进度。当你希望监控你应用中的打印任务是否完成,是否失败或者是否被用户取消,这个方法非常有用。另外,不需要创建一个应用内置的通知,因为打印框架会自动的创建一个该打印任务的系统通知。