1.0.1 • Published 2 months ago

memobird v1.0.1

Weekly downloads
3
License
MIT
Repository
github
Last release
2 months ago

memobird

咕咕机 Node.js SDK

Updates

  • 适配最新咕咕机API接口(V0.5)
  • 新增网页打印,HTML打印功能
  • 新增图片打印在线转码的支持,打印图片不再必须安装 graphicsmagick
  • 修复了若干问题

安装和使用

安装

npm install memobird

初始化

const Memobird = require('Memobird');

const memobird = new Memobird({
  ak: 'xxxxxxxxxxxxxxxx',
  memobirdID: 'xxxxxxxx',
  useridentifying: 'xxx',
});

打印

打印文字

printText(text)

memobird.init()
  .then(() => memobird.printText('你好咕咕机'))

打印图片

由于咕咕机要求的图片数据必须是 bmp 单色点位图 base64 编码,所以打印 jpeg 或者 png 等格式的图片需要使用到图片转码的功能。本模块提供了本地转码和在线转码两种方式。

printImage(image, width)

  • image 图片的本地路径 图片的网络地址 * 图片数据的 base64 编码
  • width 缺省 => 使用在线转码 提供 => 使用本地转码
memobird.init()
  .then(() => memobird.printImage('./examples/local-image.png'))
  .then(() => memobird.printImage('https://assets-cdn.github.com/images/modules/logos_page/GitHub-Mark.png'))
  .then(() => memobird.printImage(''))

在线转码图片(缺省 width 参数)

在线转码是利用了咕咕机API的获取单色位图接口,这个接口只能处理 jpeg 和 png 格式的图片,并且不能调整图片宽度。缺省width参数就会使用在线转码的方式。

memobird.init()
  .then(() => memobird.printImage('./examples/local-image.png'))

本地转码图片 (提供 width 参数)

本地转码支持更多的图片格式,而且能够调整图片的打印宽度。使用本地转码需要先安装graphicsmagick。提供width参数就会使用本地转码的方式。

memobird.init()
  .then(() => memobird.printImage('./examples/local-image.png', 50))

打印网页

printUrl(url)

memobird.init()
  .then(() => memobird.printUrl('http://open.memobird.cn/Home/testview'))

打印Html

printHtml(htmlString)

memobird.init()
  .then(() => memobird.printHtml('<html><body><h1>Hello World!</h1></body></html>'))

打印Canvas

很多场景下,我们需要打印更丰富的内容。 可以使用 canvas 精确控制自己想呈现的内容,并利用我编写的模块 binary-bmp 将 canvas 对象处理单色点位图 base64 编码值。得到编码值以后,传入 print 方法打印。canvas 可以是浏览器中的 <canvas> 或者 Node.js 中的实现的服务端 canvas 比如 node-canvas 参考 examples/canvas/server.js

浏览器中:

import Bmp from 'binary-bmp';

const canvas = document.getElementById('canvas-id'); // 获取canvas对象
const bitmap = new Bmp(Bmp.BINARY, canvas);
const base64 = bitmap.flip().getBase64(true); // 将canvas转为单色点位图base64编码值
const item = `P:${base64}`; // 咕咕机要求的格式: 'P:图片'
// ...
// 省略代码:将item的值传给服务器
// ...

服务器中:

// ...
// 省略代码:接收客户端发来的item的值
// ...
memobird.init()
  .then(() => memobird.print(item));

一次打印多个

咕咕机每次打印一份内容都会留出上下间距,如果你不想看到这些上下间距可以选择一次性打印多个内容。

print(item1, item2, ...)

  • item: 要打印的内容,是以 encode 开头命名的方法的返回值

encode 类型方法:

  • printText(text) == print(encodeText(text))
  • printImage(image, width) == print(encodeImage(image, width))
  • printCanvas(canvas) == print(encodeCanvas(canvas))
memobird.init()
  .then(() => memobird.print(
    memobird.encodeText('你好咕咕机,能不能一次性打印所有东西?'),
    memobird.encodeImage('./examples/local-image.png', 100),
  ));

获取打印状态

延时获取打印状态

glance(printcontentid, delay)

  • printcontentid: 打印内容唯一 ID, 由所有以 print 开头命名的方法返回
  • delay: 延时,即等待多少毫秒后再执行获取打印状态,默认1000。
memobird.init()
  .then(() => memobird.printText('你好咕咕机'))
  .then(printcontentid => memobird.glance(printcontentid, 1000))
  .then(printflag => console.log('打印状态:', printflag));

监听打印状态

watch(printcontentid, interval, max)

  • printcontentid: 打印内容唯一 ID, 由所有以 print 开头命名的方法返回
  • interval: 监听周期, 默认3000
  • max: 监听超时,即超出多少毫秒后立即终止监听,默认15000。

当打印时间难以预测时,watch 方法可以隔一段时间获取一次打印状态,只有当打印状态为已完成或监听时间超时时才终止。

memobird.init()
  .then(() => memobird.printImage('https://assets-cdn.github.com/images/modules/logos_page/GitHub-Mark.png'))
  .then(printcontentid => memobird.watch(printcontentid, 3000, 15000))
  .then(printflag => console.log('打印状态:', printflag));

示例

参考 examples/index.js

const Memobird = require('../');

const memobird = new Memobird({
  ak: 'xxxxxxxxxxxxxxxx',
  memobirdID: 'xxxxxxxx',
  useridentifying: 'xxx',
});

memobird.init()
  // 打印文本
  .then(() => memobird.printText('你好咕咕机!'))
  // 3000毫秒后获取打印状态
  .then(printcontentid => memobird.glance(printcontentid, 3000))
  .then(printflag => console.log('打印状态:', printflag === 1 ? '已打印' : '未打印'))

  // 打印图片
  .then(() => memobird.printImage('https://assets-cdn.github.com/images/modules/logos_page/GitHub-Mark.png'), 100)
  // 每3000毫秒获取一次打印状态,如果显示未打印则继续获取,当获取到结果为已打印的状态或总用时超出15000毫秒,则终止并返回结果
  .then(printcontentid => memobird.watch(printcontentid, 3000, 15000))
  .then(printflag => console.log('打印状态:', printflag === 1 ? '已打印' : '未打印'))

  // 一次性打印多个
  .then(() => memobird.print(
    memobird.encodeText('你好咕咕机,能不能一次性打印所有东西?'),
    memobird.encodeText('第一张图片:'),
    memobird.encodeImage('https://assets-cdn.github.com/images/modules/logos_page/GitHub-Mark.png', 50),
    memobird.encodeText('第二张图片:'),
    memobird.encodeImage('https://assets-cdn.github.com/images/modules/logos_page/GitHub-Mark.png', 100),
    memobird.encodeText('第三张图片:'),
    memobird.encodeImage('https://assets-cdn.github.com/images/modules/logos_page/GitHub-Mark.png')
  ))
  .catch(error => console.log('打印出错了:', error));
1.0.1

2 months ago

1.0.0

2 months ago

0.5.2

6 years ago

0.5.1

6 years ago

0.5.0

6 years ago

0.0.9

6 years ago

0.0.8

6 years ago

0.0.6

7 years ago

0.0.5

7 years ago

0.0.4

7 years ago

0.0.3

7 years ago

0.0.2

7 years ago

0.0.1

7 years ago