ReactNative相关

android版蓝牙打印机使用方式

  1. 导入 gprintersdkv2.1.4.jar jar包

  2. 导入 BluetoothModule , BluetoothPort ,BluetoothUtil ,PrinterPackage四个类文件
    并向MainApplication中添加

        protected List getPackages() {
            return Arrays.asList(
                    new MainReactPackage(),
                    new PrinterPackage()//添加到这儿
            );
        } 
  1. 配置build.gradle compile files('libs/gprintersdkv2.1.4.jar') 引用导入的jar包

  2. 在ReactNative中引用 创建一个新的js文件,在其中引用原生文件

    import {NativeModules} from 'react-native';
    
    module.exports = NativeModules.BluetoothModule;
    
  3. 使用方法

    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

  1. 将生成的秘钥文件放到工程下的 android/app 文件夹下
  2. 编辑~/.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 删除某个 access-key

在CodePush服务器上注册你的APP

  控制台执行`code-push app add `,将你的app注册至CodePush服务器

相关命令

  • add 在账号里面添加一个新的app
  • remove 或者 rm 在账号里移除一个app
  • rename 重命名一个存在app
  • list 或者 ls 列出账号下面的所有app
  • transfer 把app的所有权转移到另外一个账号

添加SDK以及相关代码

  1. 在工程下安装RN插件 npm install --save react-native-code-push
  2. 安装rnpm npm i rnpm
  3. 运行rnpm link react-native-code-push,自动配置相关设置
  4. 运行 code-push deployment ls ,获取app的部署秘钥,默认为staging,所以使用staging的就可以.
  5. 在MainApplication中配置秘钥 @Override protected List getPackages() { return Arrays.asList( new MainReactPackage(), new CodePush("deployment-key-here", MainApplication.this, BuildConfig.DEBUG) ); }
  6. android/app/build.gradle中有个android.defaultConfig.versionName属性,徐阿哟把应用版本改为三位数,例如将1.0改为1.0.0
    android{
        defaultConfig{
            versionName "1.0.0"
        }
    }
  1. 在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  <文件路径> <版本号,指的是app的版本号,在build.gradle中查看>
 例如 `code-push release PrinterDemo ./bundles 1.0.1`

你可能感兴趣的:(ReactNative相关)