android版蓝牙打印机使用方式
导入
gprintersdkv2.1.4.jar
jar包导入
BluetoothModule , BluetoothPort ,BluetoothUtil ,PrinterPackage
四个类文件
并向MainApplication中添加
protected List<ReactPackage> getPackages() {
return Arrays.<ReactPackage>asList(
new MainReactPackage(),
new PrinterPackage()//添加到这儿
);
}
配置build.gradle
compile files('libs/gprintersdkv2.1.4.jar')
引用导入的jar包-
在ReactNative中引用 创建一个新的js文件,在其中引用原生文件
import {NativeModules} from 'react-native'; module.exports = NativeModules.BluetoothModule;
-
使用方法
import {Bluetooth,Printer} from './PrinterUtils/Bluetooth'; //蓝牙 Bluetooth.isSupport(); //判断是否支持蓝牙,返回boolean Bluetooth.isEnabled();//判断蓝牙是否启用 ,返回boolean Bluetooth.enableBluetooth();//开启蓝牙 Bluetooth.getBondedDevices();//获取已配对设备,返回对象集合 Bluetooth.discoveryhDevices();//搜索附近蓝牙设备,返回设备对象的集合 Bluetooth.bondDevice(String deviceAddress); //传入设备的Mac地址,返回配对结果的boolean //打印 Printer.connect();//获取socket,获得传输数据的流 Printer.addText(String str);//打印文本,默认UTF-8 Printer.addFeedLine();//走纸一行 Printer.addFeedLines(number n);//走纸n行 Printer.alignInPageLeft();//设置打印内容居于页面左侧 Printer.alignInPageCenter();//设置打印内容居于页面中间 Printer.alignInPageRight();//设置打印内容居于页面右侧 Printer.setTextSizeZoom2();//设置打印文本放大两倍 Printer.setTextSizeZoom1();//设置打印文本为默认大小 Printer.setMarginLeft(number marginLeft);//设置打印内容距离左边的边距 Printer.print();//执行打印 Printer.disConnect();//断开与打印机的Socket以及数据流的关闭
生成已签名apk
生成秘钥文件
在命令行使用keytool进行生成,生成文件在当前目录下
$ keytool -genkey -v -keystore <秘钥文件名称,以.keystore结尾> -alias <证书名称> -keyalg RSA -keysize 2048 -validity 10000
点击生成以后需要按步骤输入证书信息以及密码,证书信息和秘钥信息可以使用相同的
配置gradle
- 将生成的秘钥文件放到工程下的
android/app
文件夹下 - 编辑
~/.gradle/gradle.properties
或者android/gradle.properties
,前者为全局变量,后者为当前工程的变量.添加如下的代码(注意把其中的****替换为相应密码)
MYAPP_RELEASE_STORE_FILE=<秘钥文件名称>
MYAPP_RELEASE_KEY_ALIAS=<证书名称>
MYAPP_RELEASE_STORE_PASSWORD=*****
MYAPP_RELEASE_KEY_PASSWORD=*****
添加签名到应用的build.gradle配置文件
编辑你工程目录下的android/app/build.gradle,添加如下的内容:
android {
...
defaultConfig { ... }
signingConfigs {
release {
storeFile file(MYAPP_RELEASE_STORE_FILE)
storePassword MYAPP_RELEASE_STORE_PASSWORD
keyAlias MYAPP_RELEASE_KEY_ALIAS
keyPassword MYAPP_RELEASE_KEY_PASSWORD
}
}
buildTypes {
release {
...
signingConfig signingConfigs.release
}
}
}
生成发行APK包
如果你在android/app下有一个react.gradle
只要在终端下运行以下命令:
$ cd android && ./gradlew assembleRelease
如果你没有react.gradle文件:
$ mkdir -p android/app/src/main/assets
$ react-native bundle --platform android --dev false --entry-file index.android.js \
--bundle-output android/app/src/main/assets/index.android.bundle \
--assets-dest android/app/src/main/res/
$ cd android && ./gradlew assembleRelease
该命令将js文件打包成bundle文件存放在 android/app/src/main/assets/index.android.bundle 中
生成成功后
android/app/build/outputs/apk/app-release.apk
文件就可以用来进行应用的发布
测试应用的发行版本
$ cd android && ./gradlew installRelease
执行该条命令,即可将打包后的app安装至连接起的手机中
重新打包
重新打包时,需要重新生成bundle文件,执行
react-native bundle --platform android --dev false --entry-file index.android.js \ --bundle-output android/app/src/main/assets/index.android.bundle \ --assets-dest android/app/src/main/res/
以及$ cd android && ./gradlew assembleRelease
android使用CodePush实现热更新
安装code-push
在控制台输入 `npm install -g code-push-cli`,就可以安装了
安装完毕,控制台输入` code-push -v` 查看版本代表成功
创建code-push 账号
在控制台输入`code-push register `后,将会打开一个网页进行注册
相关命令
- code-push login 登陆
- code-push loout 注销
- code-push access-key ls 列出登陆的token
- code-push access-key rm <accessKye> 删除某个 access-key
在CodePush服务器上注册你的APP
控制台执行`code-push app add <appName>`,将你的app注册至CodePush服务器
相关命令
- add 在账号里面添加一个新的app
- remove 或者 rm 在账号里移除一个app
- rename 重命名一个存在app
- list 或者 ls 列出账号下面的所有app
- transfer 把app的所有权转移到另外一个账号
添加SDK以及相关代码
- 在工程下安装RN插件
npm install --save react-native-code-push
- 安装rnpm
npm i rnpm
- 运行
rnpm link react-native-code-push
,自动配置相关设置 - 运行
code-push deployment ls <appName>
,获取app的部署秘钥,默认为staging,所以使用staging的就可以. - 在MainApplication中配置秘钥
@Override protected List<ReactPackage> getPackages() { return Arrays.<ReactPackage>asList( new MainReactPackage(), new CodePush("deployment-key-here", MainApplication.this, BuildConfig.DEBUG) ); }
-
android/app/build.gradle
中有个android.defaultConfig.versionName
属性,徐阿哟把应用版本改为三位数,例如将1.0
改为1.0.0
android{
defaultConfig{
versionName "1.0.0"
}
}
- 在js中使用
import CodePush from 'react-native-code-push' //检查更新 CodePush.checkForUpdate() .then( (update) =>{ if( !update ){ console.log("app是最新版了"); }else { console.log("有更新哦"); } }); //进行下载和安装更新
CodePush.sync();
//检查更新之后必须调用,否则会进行回滚
CodePush.notifyApplicationReady();
```
发布更新
在工程目录下创建 bundles文件夹 ` mkdir bundles`
重新生成打包文件并且放到bundles文件夹下 `react-native bundle --platform 平台 --entry-file 启动文件 --bundle-output 打包js输出文件 --assets-dest 资源输出目录 --dev 是否调试`
例如 `react-native bundle --platform android --entry-file index.android.js --bundle-output ./bundles/index.android.bundle --dev false`
打包结束,通过CodePush进行更新
> code-push release <AppName> <文件路径> <版本号,指的是app的版本号,在build.gradle中查看>
例如 `code-push release PrinterDemo ./bundles 1.0.1`