ReactNative相关

android版蓝牙打印机使用方式

  1. 导入 gprintersdkv2.1.4.jar jar包

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

        protected List<ReactPackage> getPackages() {
            return Arrays.<ReactPackage>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 <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以及相关代码

  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 <appName>,获取app的部署秘钥,默认为staging,所以使用staging的就可以.
  5. 在MainApplication中配置秘钥 @Override protected List<ReactPackage> getPackages() { return Arrays.<ReactPackage>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 <AppName> <文件路径> <版本号,指的是app的版本号,在build.gradle中查看>
 例如 `code-push release PrinterDemo ./bundles 1.0.1`
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,042评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,996评论 2 384
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,674评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,340评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,404评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,749评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,902评论 3 405
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,662评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,110评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,451评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,577评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,258评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,848评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,726评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,952评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,271评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,452评论 2 348

推荐阅读更多精彩内容