hybird app(混合式app开发)cordova ionic 创建相应平台的app

时间:2021-01-27 15:31:57

hybird app(混合式app开发)

之ionic 框架平台 guide

cordova 创建相应平台的app

1. npm install -g cordova //全局安装cordova-cli

2.cordova create hello com.example.hello HelloWorld  
//创建 hello:项目文件夹名, com.example.hello:java包名 HelloWorld:app应用安装名

3. cd hello
 cordova platform add ios --save   //添加平台 ios需要mac osx操作系统
 cordova platform add android --save
 cordova platform ls  // 列出项目现在支持的平台(添加过的平台)

4.
4.1检查开发环境要求是否ok  (比如开发android,需要的基础要求jdk,和android sdk,相应配置放在文下面)
cordova requirements

4.2检查项目运行配置(相应配置放在文下面)
运行app需要一个AVD(Android Virtual Device)安卓虚拟机,或者说安卓模拟器(Android emulator)

5.构建app (build app)
cordova build  // 构建全部添加平台的app
cordova build ios // 指定构建平台的app
//生成的apk文件在 platforms/android/build/outputs/apk/下

6.测试app
cordova emulate android  
//第一次运行命令由于android虚拟机启动很缓慢而且在pc极卡,所以可能会超时而失败,
不关闭启动的虚拟机,重试此命令即可用同一个虚拟机实例重复以上rebuild,在虚拟机上安装apk,run的步骤
退出后也可在安装的应用主页中看到相应的应用
或者
使用插入pc的手机测试
$ cordova run android
 note:
 需手机连接pc打开usb调试
 使用 cordova run --list 查看(可用设备)available device
 若无打开pc上的设备管理器,查看adb interface的驱动是否有叹号
 
 有叹号则安装驱动:
 http://adbdriver.com/  通用adb驱动    
    在windows8,10上不能安装 unsigned drivers because the system enables driver signature enforcement by default.
    http://adbdriver.com/documentation/how-to-install-adb-driver-on-windows-8-10-x64.html
装完驱动后再运行 cordova run android即可

7.添加插件 add plugin
(通过安装插件库的方式,为js api提供本地sdk函数的调用,插件库放在npm仓库上,使用npm安装)
比如照相机

插件搜索
$ cordova plugin search camera

插件安装
$ cordova pluign add cordova-plugin-camera
  // Fetching plugin "cordova-plugin-camera@~2.1.0" via npm
  // Installing "cordova-plugin-camera" for android
  // Installing "cordova-plugin-camera" for ios
  // ...

8.定制不同平台(using merges)

不要直接去修改 platforms下第一级子目录下www文件夹内的内容,因为在编译转换过程中它们会被跨平台的项目根目录下的www下的文件所替换
每个平台下的子目录 'merges' 提供了地方去放那些特定平台下的内容允许你覆盖或者新加文件到特定平台

编辑www/index.html 增加
<link rel="stylesheet" type="text/css" href="css/overrides.css" />

添加一个空的www/css/overrides.css  防止其他平台编译时error找不到文件

merges/android 下增加css/目录 在这个目录下写 overrides.css 的相应代码

merges新增相应平台的文件 比如ios平台增加一个后退按钮
merges/ios/img/back_button.png

9.cordova的更新
$ sudo npm update -g cordova

更新平台
$ cordova platform update android --save
$ cordova platform update ios --save

其它 :
启动www目录的本地 web服务器
 cordova serve [port]  // 不指定端口则默认监听8000

访问项目:http://HOST_IP:PORT/PLATFORM/www

查看帮助:
cordova help [command]
cordova [command] -h
cordova -h [command]

4.1
安装好jdk并设置类似:
JAVA_HOME=C:\Program Files\Java\jdk1.7.0_67

下载好android sdk后
1.sdk manager 安装包 install package  (有点儿漫长的安装过程...文件很多也很占空间)
    note:
    1.Tools目录全选
    主要安装 :
    Android SDK Tools
    Android SDK Platform-tools
    Android SDK Build-tools (highest version)

2.选择安装多个 Android X.X
    主要安装:    
    SDK Platform
    A system image for the emulator, such as
    ARM EABI v7a System Image
        关于安卓系统的模拟cpu
        Intel x86 Atom System Image是支持X86的Android模拟器,ARM EABI v7aSystem Image是模拟ARM体系,创建模拟器时模拟的CPU不同,ARM运行速度较慢,所以Intel推出了支持x86的Android模拟器,这将大大提高启动速度和程序的运行速度,允许Android模拟器以原始速度(真机运行速度)运行在使用Intel x86处理器的电脑中
      要使用的话需要安装 英特尔硬件加速执行管理器
      https://software.intel.com/zh-cn/android/articles/intel-hardware-accelerated-execution-manager
      在SDK中勾选Android版本对应的Intel x86 Atom System Image点击Install package即可
        注意:Intel x86 Atom System Image仅仅是X86版本的模拟器 不是Android版本

2.设置环境变量
'ANDROID_HOME'  C:\Program Files (x86)\Android\android-sdk
path下追加    %ANDROID_HOME%\platform-tools;%ANDROID_HOME%\tools;

验证配置: 命令行运行 adb 和 android list 有反应说明配置ok

4.2项目配置(运行用的虚拟机配置)
运行app需要一个AVD(Android Virtual Device)安卓虚拟机,安卓模拟器(Android emulator)
    配置avd
    $ android avd

相关设置说明:
skin:
nexus 5 尺寸: 360x640 像素1920x1080
定制Android模拟器skin
参考:http://blog.chinaunix.net/uid-10212972-id-2969114.html

标屏        分辨率        宽屏        分辨率

QVGA        ×     WQVGA       320x480
WQVGA2 400x240
WQVGA3 432x240 VGA × WVGA ×
WVGA2 *
FWVGA *
HVGA ×
DVGA 960x640
SVGA × WSVGA × / *
XGA × WXGA × / × / *
SXGA × WXGA+ ×
SXGA+ × WSXGA+ ×
UXGA × WUXGA ×
QXGA × WQXGA × PAL *
NTSC * VGA:Video Graphics Array,即:显示绘图矩阵,相当于640× 像素;
HVGA:Half-size VGA,即:VGA的一半,分辨率为480×,像三星盖世Ace S5830就是使用这分辨率
QVGA:Quarter VGA,即:VGA的四分之一,分辨率为320×,一般用于小屏手机 像三星盖世Mini S5570就是使用这分辨率;
WQVGA:Wide Quarter VGA,即:扩大的QVGA,分辨率比QVGA高,比VGA低,一般是:×,×;
WVGA:Wide Video Graphics Array,即:扩大的VGA,分辨率为800×480像素,像三星i9000就是使用这分辨率;
FWVGA:Full Wide VGA ,数码产品屏幕材质的一种,VGA的另一种形式,比WVGA分辨率高,别名 : Full Wide VGA, ,其分辨 率为854×480象素(:) ×, portrait : emulator -skin QVGA-P
×, landscape: emulator -skin QVGA-L
×, portrait : emulator -skin HVGA-P (default)
×, landscape: emulator -skin HVGA-L

2.使用ionic框架

1.npm -g cordova ionic

2.建立ionic项目
$ ionic start myApp tabs   //myApp:项目名文件夹名 tabs:初始类型

新建的基础项目:
$ ionic start myApp blank
$ ionic start myApp tabs
$ ionic start myApp sidemenu

3.设置项目:
cd myApp
ionic setup sass  //设置项目使用sass
$ ionic platform add ios  // 添加相应平台 ios / android
$ ionic build ios         // 构建相应平台的app

4.运行预览项目app
ionic serve       //浏览器查看并(实时重载)live reload
$ ionic emulate ios     // 调用那个平台的模拟器测试app

目前ionic构建的app支持
ios6+, Android4.0+

ionic start 命令将构建
如下项目结构
├── bower.json     // bower dependencies
├── config.xml     // cordova configuration
├── gulpfile.js    // gulp tasks
├── hooks          // custom cordova hooks to execute on specific commands
├── ionic.project  // ionic configuration
├── package.json   // node dependencies
├── platforms      // iOS/Android specific builds will reside here
├── plugins        // where your cordova/ionic plugins will be installed
├── scss           // scss code, which will output to www/css/
└── www            // application - JS code and libs, CSS, images, etc.

www/ index.html
www下lib/ionic/js
all AngularJS extensions in the ionic.bundle.js
推荐其它angular模块放在 lib/js/angular下

cordova.js or phonegap.js 文件在开发环境下是不可见的,但是他会包含在运行的安卓模拟器的app里

www/js
app.js(项目js入口文件)
开始写
1.编辑angular.module('todo', ['ionic'])
2.index.html添加 <script src="js/app.js"></script>
3. <body ng-app="todo">

4.做不同平台的一些特定文件和改变,可以直接将platforms/platform作为 XCode或Android Eclipse项目的根目录,
此时若工作的www目录作了一些更改,通过
$ cordova prepare ios/android  //将www/目录的更改同步的相应平台的www文件夹下

chrome上做安卓手机webapp的远程调试
http://developer.android.com/guide/webapps/debugging.html

5.写html template:
<script id="new-task.html" type="text/ng-template">
  <div class="modal">
    ...
  </div>
</script>
模板可以从本地或者远程载入,模板的url是它的id

6.加模态框后 写控制器
angular.module('todo', ['ionic'])

.controller('TodoCtrl', function($scope, $ionicModal) {
  // No need for testing data anymore
  $scope.tasks = [];

// Create and load the Modal
  $ionicModal.fromTemplateUrl('new-task.html', function(modal) {
    $scope.taskModal = modal;
  }, {
    scope: $scope,
    animation: 'slide-in-up'
  });

// Called when the form is submitted
  $scope.createTask = function(task) {
    $scope.tasks.push({
      title: task.title
    });
    $scope.taskModal.hide();
    task.title = "";
  };

// Open our new task modal
  $scope.newTask = function() {
    $scope.taskModal.show();
  };

// Close the new task modal
  $scope.closeNewTask = function() {
    $scope.taskModal.hide();
  };
});

7. 发布app时的一些工作
7.1.调整清理插件如: 构建发行版时去掉控制台输出的插件
$ cordova plugin rm cordova-plugin-console

7.2.发布
$ cordova build --release android
这行命令的生成基于config.xml的配置
自己定制此配置文件参考: http://cordova.apache.org/docs/en/latest/guide/platforms/android/config.html

7.3.
apk签名
platforms/android/build/outputs/apk/HelloWorld-release-unsigned.apk

7.3.1.
使用jdk的keytool命令行工具生成 私钥 (如果已有,可跳过)
$ keytool -genkey -v -keystore my-release-key.keystore -alias alias_name -keyalg RSA -keysize 2048 -validity 10000
输入口令,以及几个问题
生成my-release-key.keystore文件,保存这个文件,如果丢失这个文件将不能更新app.

7.3.2.
对这个未签名的apk签名 (sign the unsigned APK) 使用jdk的jarsigner命令
$ jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore my-release-key.keystore HelloWorld-release-unsigned.apk alias_name

7.3.3.使用zipalign工具优化apk (..../Android/sdk/build-tools/VERSION/zipalign):来自android sdk
 '/path/to/Android/sdk/build-tools/VERSION/zipalign' (需要选择具体版本的zipalign加入path %ANDROID_HOME%\build-tools\20.0.0;)
$ zipalign -v 4 HelloWorld-release-unsigned.apk HelloWorld.apk
得到最终的HelloWorld.apk

8.更新app 版本
修改config.xml,增加version value,然后重新构建即可

$ionic serve 命令相关选项
  restart or r        //  重启客户端app
  goto or g 然后给一个 url  // 让app导航到指定的url
  consolelogs or c    // 启用/禁用控制台输出
  serverlogs or s    //启用/禁用服务器日志输出
  quit or q    // 关闭web服务器并停止服务

视频教程: Ionic Crash Course
https://www.youtube.com/watch?v=C-UwOWB9Io4&feature=youtu.be

平台支持:
cordova -v
http://cordova.apache.org/docs/en/latest/guide/support/index.html(注意选择命令执行后得到的对应版本)

cordova:
cordova 6.0 : 需安装jdk1.7或更高  
  同时安装如android-sdk 5.1 配 android build tools 19.1.0或更高

ionic:
目前ionic构建的app支持
ios6+, Android4.0+

android:
android 6.0   (API level 23)
android 5.1.1 (API level 22)
android 4.2.2 (API level 17)
android 4.0.3 (API level 15)
android 2.3.3 (API level 10)

nexus 5 5.1
nexus 5(初上市2015 os:4.4 32GB:2600rmb)

相关文档:
http://ionicframework.com/docs/
http://docs.ionic.io/
https://cordova.apache.org/docs/en/latest/guide/overview/
http://developer.android.com/sdk/index.html#Other

上传应用:
上传google play store(应用商店)
创建开发者账号: https://play.google.com/apps/publish/   需要:$29 money
apple开发者需要 $99 money

ionic已经包含一些app的样式详见: http://ionicframework.com/docs/components/#header

ionic 平台定制
几种方式:
1. platform classes
2.使用js ,angularjs with style
3.dynamic template

1.platform classes
ionic会在不同设备上的app的body元素上添加特定class
比如在ios上会添加 class=" platform-ios"

1.1 platform device class:
浏览器         platform-browser     当应用程序运行在电脑桌面版的浏览器里时,比如你使用ionic serve 命令调试时
Cordova     platform-cordova     当应用程序运行在设备上,设备使用cordova来显示时
Webview     platform-webview     当应用程序运行在Webview的本地应用程序时
iOS         platform-ios         当应用程序运行在ios设备上时
iPad         platform-ipad         当应用程序运行在ios 的ipad设备,它会附加到platform-ios上
Android         platform-android     当应用程序运行在安卓设备上时
Windows Phone     platform-windowsphone     当应用程序运行在windows phone上时

1.2 platform os version class: (不同操作系统版本的类)
iOS 8         platform-ios8         设备上的操作系统是ios8
iOS 8.4     platform-ios8_4     设备上的操作系统是ios8.4,这个类会被附加到platfrom-ios8后
Android 4     platform-android4     设备上的操作系统是安卓4
Android 4.4     platform-android4_4     设备上的操作系统是android4.4,这个类会被附加到platfrom-android4后

使用示例:
.platform-android .bar-header {
  text-transform: uppercase;  
}

2.使用工具模块制定相应样式 ionic.Platform

示例:
.controller('AppCtrl', function($scope) {
  $scope.platform = ionic.Platform.platform();  //得到平台 android/ios /...
});

元素上:
<ion-tabs class="tabs-stable" ng-class="{'tabs-positive': platform == 'android', 'tabs-icon-top': platform != 'android'}">
  <!-- ion-tab directives go here -->
</ion-tabs>

<!-- if the platform is android don't add an icon, all other devices get an icon -->
<ion-tab title="Home" ng-attr-icon="{{ platform != 'android' ? 'ion-home' : undefined}}" href="#/tab/home">

3.根据不同的平台加载不同平台的html template
.state('tab', {
  url: "/tab",
  abstract: true,
  controller: 'AppCtrl',
  templateUrl: function() {
    if (ionic.Platform.isAndroid()) {
        return  "templates/home-android.html";
    }
    return "templates/home.html";
  }
})

3.2. cordova的merges目录不再默认加入项目中了,但是它仍然是一个很有用的工具用来定制不同平台的app,
你可以在项目第一级路径下(和www 或者platforms同级)加merges目录

可参考:http://cordova.apache.org/docs/en/3.5.0/guide/cli/index.html#The%20Command-Line%20Interface_using_merges_to_customize_each_platform

示例:
如果每个平台有自己单独的index.html
merges/
    ios/
        index.html
    android/
        index.html

覆盖重写css js文件
merges/
    ios/
        index.html
        css/
            platform.css
        js/
            app.js
    android/
        index.html
        css/
            platform.css
        js/
            app.js

javascript 部分:

1.$ionicActionSheet
向上推出的面板,让用户选择一些选项,危险选项红色高亮

使用: controller内注入 $ionicActionSheet
示例:
.controller(function($scope, $ionicActionSheet, $timeout) {

// Triggered on a button click, or some other target
 $scope.show = function() {

// Show the action sheet
   var hideSheet = $ionicActionSheet.show({
     buttons: [
       { text: '<b>Share</b> This' },
       { text: 'Move' }
     ],
     destructiveText: 'Delete',
     titleText: 'Modify your album',
     cancelText: 'Cancel',
     cancel: function() {
          // add cancel code..
        },
     buttonClicked: function(index) {
       return true;
     }
   });

// For example's sake, hide the sheet after two seconds
   $timeout(function() {
     hideSheet();
   }, 2000);

};
});

选项: http://ionicframework.com/docs/api/service/$ionicActionSheet/

2.$ionicBackdrop
灰色背景,在popup等一些或其它html表面的
多个ui组件都需要这样一个灰色背景,但是在同一时间dom上只需要一个灰色背景
因此每个组件显示backdrop的时候都调用 $ionicBackdrop.retain();,
当动作完成释放它时调用 $ionicBackdrop.release();

每次retain()后都需要release(),backdrop才会消失
如果调用三次retain(),那么也需要调用三次release()才会消失backdrop.

$ionicBackdrop 会从rootScope向下级scope广播 backdrop.shown 和 backdrop.hidden 事件

示例:
function MyController($scope, $ionicBackdrop, $timeout, $rootScope) {
  //Show a backdrop for one second
  $scope.action = function() {
    $ionicBackdrop.retain();
    $timeout(function() {
      $ionicBackdrop.release();
    }, 1000);
  };

// Execute action on backdrop disappearing
  $scope.$on('backdrop.hidden', function() {
    // Execute action
  });

// Execute action on backdrop appearing
  $scope.$on('backdrop.shown', function() {
    // Execute action
  });

}

3.content

$ionicScrollDelegate:
ionContent 指令可以很方便的配置使用ionic定制scroll view,或使用浏览器overflow 的scroll

可以使用 ionRefresher 指令实现下拉刷新
可以使用 ionInfiniteScroll 指令实现 无限滚动

如果ion-content内的内容是动态的,确保在内容加载后再触发$ionicScrollDelegate 的resize()方法.

ionic-cli
更新ionic
$ ionic lib update
如果安装了bower,这行命令将调用 bower update ionic,否则的话,命令行会从ionic'CDN上下载更新本地静态的ionic文件

在手机端或者模拟器调试时继续使用live reload

run / emulate 命令时加上 --livereload

当live reload被启用了,调试信息一样可以通过--consolelogs 或者 -c

[--livereload|-l] .......  Live Reload app dev files from the device (beta)
[--consolelogs|-c] ......  Print app console logs to Ionic CLI (live reload req.)
[--serverlogs|-s] .......  Print dev server logs to Ionic CLI (live reload req.)
[--port|-p] .............  Dev server HTTP port (8100 default, live reload req.)
[--livereload-port|-i] ..  Live Reload port (35729 default, live reload req.)
[--debug|--release]

Generate splash screens and icons with ionic resource
http://ionicframework.com/blog/automating-icons-and-splash-screens/

cd [project]

ionic login  // 输入ionic 邮箱名和登录密码

ionic upload // 上传