Bootstrap

鸿蒙网络编程系列39-Web组件打印示例

1. web组件打印简介

web组件在加载了网页以后,有两种方式可以实现打印,第一种是在网页中调用W3C标准协议接口window.print()进行打印,这种方式比较简单方便,只要网页中触发了该方法即可打印,缺点是如果网页没有地方触发则不能打印;另外一种是在应用侧实现的,通过web控制器的createWebPrintDocumentAdapter方法创建打印适配器,然后将适配器传入打印的print接口即可调起打印,虽然有点复杂,但是可以打印任何网页;本文将分别演示这两种打印方式的实现。

2. web组件打印演示

本示例运行后的界面如图所示,这里的网页使用的是应用内置的html资源文件:

单击网页中的“打印”按钮,即可弹出打印页面如图所示:

页面的上部为打印预览,下部为打印配置。

如果不使用页面内的打印按钮,而是单击应用侧的“打印”按钮(确保不选中“打印背景”选项),则会弹出如下的打印页面:

这里的预览页面没有显示背景色,如果要打印背景色,可以选中“打印背景”选项。

3. web组件打印示例编写

下面详细介绍创建该示例的步骤。

步骤1:创建Empty Ability项目。

步骤2:在module.json5配置文件加上对权限的声明:

"requestPermissions": [
      {
        "name": "ohos.permission.INTERNET"
      }
    ]

这里添加了访问互联网的权限。

步骤3:添加print.html资源文件,该文件即为web组件加载的html文件,内容如下:

<!DOCTYPE html>
<html>

<body style="background-color: lightblue;">
<div style="text-align: center;">
    <h1>
        打印测试页
    </h1>
    <button onclick="window.print();">打印</button>
    <p> 网页内容 </p>
    <p style="color: blue;"> 打印Web组件中的网页内容示例 </p>
</div>
</body>

步骤4:在Index.ets文件里添加如下的代码:

import web_webview from '@ohos.web.webview'
import { print } from '@kit.BasicServicesKit';

@Entry
@Component
struct Index {
  //是否打印背景
  @State printBackground: boolean = false
  scroller: Scroller = new Scroller()
  controller: web_webview.WebviewController = new web_webview.WebviewController()
  webPrintAdapter?: print.PrintDocumentAdapter

  build() {
    Row() {
      Column() {
        Text("Web组件打印")
          .fontSize(14)
          .fontWeight(FontWeight.Bold)
          .width('100%')
          .textAlign(TextAlign.Center)
          .padding(10)

        Flex({ justifyContent: FlexAlign.End, alignItems: ItemAlign.Center }) {
          Text("打印背景")
            .fontSize(14)

          Checkbox()
            .select($$this.printBackground)
            .shape(CheckBoxShape.ROUNDED_SQUARE)

          Button("打印")
            .onClick(() => {
              this.print()
            })
            .width(60)
            .fontSize(14)
        }
        .width('100%')
        .padding(5)

        Scroll(this.scroller) {
          Web({ src: $rawfile("print.html"), controller: this.controller })
            .padding(10)
            .width('100%')
            .textZoomRatio(150)
            .backgroundColor(0xeeeeee)
            .javaScriptAccess(true)
        }
        .align(Alignment.Top)
        .backgroundColor(0xeeeeee)
        .height(300)
        .flexGrow(1)
        .scrollable(ScrollDirection.Vertical)
        .scrollBar(BarState.On)
        .scrollBarWidth(20)
      }
      .width('100%')
      .justifyContent(FlexAlign.Start)
      .height('100%')
    }
    .height('100%')
  }

  //打印web组件内容
  print() {
    if (this.webPrintAdapter == undefined) {
      this.webPrintAdapter = this.controller.createWebPrintDocumentAdapter("webPrint");
    }

    this.controller.setPrintBackground(this.printBackground)
    print.print("printJob", this.webPrintAdapter, null, getContext())
      .then((task: print.PrintTask) => {
        task.on('succeed', () => {
          console.log('打印成功!');
        })
      })
  }
}

步骤5:编译运行,建议使用真机。

步骤6:按照本节第2部分“web组件打印演示”操作即可。

4. 代码分析

本示例代码较简单,需要注意的是网页内打印调用方法,即window.print();另外一点是在应用侧打印时,注意不要多次创建打印适配器,本示例是通过判断打印适配器的变量是否为undefined实现的。

(本文作者原创,除非明确授权禁止转载)

本文源码地址:

https://gitee.com/zl3624/harmonyos_network_samples/tree/master/code/web/WebPrint

本系列源码地址:

https://gitee.com/zl3624/harmonyos_network_samples

;