最近我在尝试了解跨平台技术的发展,首先则是想到了cordova
。本文简单记录下cordova
环境搭建的过程。javascript
首先是要npm
全局安装cordova
html
npm install -g cordova
复制代码
安装的cordova
相似于create-react-app
这种脚手架,能够经过命令行直接建立应用java
cordova create myapp
复制代码
cordova
能够支持ios
, android
, web
三端。react
cordova platform add ios
cordova platform add android
cordova platform add browser
复制代码
进入android
目录下,能够看到不少.java
文件,而ios
目录下是不少的object-c
文件,browser
目录下则是熟悉的web
工程。android
而且能够看到,每一个平台下都有一个cordova
目录,我初步猜测,这应该是负责和不一样平台通信交互的cordova
核心。ios
web
端是最直观最简单的,直接运行以下命令便可。web
cordova run browser
复制代码
对于Android
和IOS
,咱们则须要先检查相关环境是否安装正常。shell
$ cordova requirements
Requirements check results for android:
Java JDK: installed 1.8.0
Android SDK: not installed
Failed to find 'ANDROID_HOME' environment variable. Try setting it manually.
Detected 'adb' command at C:\Windows\system32 but no 'platform-tools' directory found near.
Try reinstall Android SDK or update your PATH to include valid path to SDK\platform-tools directory.
Android target: not installed
android: Command failed with exit code ENOENT Error output:
'android' �����ڲ����ⲿ���Ҳ���ǿ����еij���
�����������
Gradle: not installed
Could not find gradle wrapper within Android SDK. Could not find Android SDK directory.
Might need to install Android SDK or set up 'ANDROID_HOME' env variable.
Requirements check results for browser:
Requirements check results for ios:
Apple macOS: not installed
Cordova tooling for iOS requires Apple macOS
Some of requirements check failed
复制代码
能够看到,个人电脑环境并不知足android
和ios
平台的要求。npm
首先咱们来知足下android
平台的环境要求。小程序
首先是JDK
,能够经过java
和javac
命令来检查下。
C:\>java -version
java version "1.8.0_201"
Java(TM) SE Runtime Environment (build 1.8.0_201-b09)
Java HotSpot(TM) 64-Bit Server VM (build 25.201-b09, mixed mode)
复制代码
若是没安装,能够参考jdk下载与安装简明教程。
Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化构建开源工具。
具体安装过程能够参考gradle环境搭建。
首先咱们安装Android Studio。根据安装指引,咱们会安装好Android SDK
。
在此安装过程当中,遇到了一个报错:
Android SDK Tools, SDK Patch Applier v4 and 5 more SDK components were not installed
复制代码
感谢这位大佬提供的解决方案,迅速解决了问题,这里顺便记下SDK
的安装目录。
C:\Users\Jiang.Wenbin\AppData\Local\Android\Sdk
复制代码
接着咱们须要在环境变量-系统变量-Path中新增两项:
C:\Users\Jiang.Wenbin\AppData\Local\Android\Sdk\platform-tools
C:\Users\Jiang.Wenbin\AppData\Local\Android\Sdk\tools
复制代码
而且新增一项系统变量ANDROID_HOME,变量值为:
C:\Users\Jiang.Wenbin\AppData\Local\Android\Sdk
复制代码
试运行命令cordova run android
,出现了以下警告
$ cordova run android
Checking Java JDK and Android SDK versions
ANDROID_SDK_ROOT=undefined (recommended setting)
ANDROID_HOME=C:\Users\Jiang.Wenbin\AppData\Local\Android\Sdk (DEPRECATED)
Starting a Gradle Daemon (subsequent builds will be faster)
复制代码
因而我又新增了一项系统变量ANDROID_SDK_ROOT,变量值与ANDROID_HOME同样。
从新跑cordova run android
命令,首先看到警告以下:
> Configure project :app
Checking the license for package Android SDK Platform 28 in C:\Users\Jiang.Wenbin\AppData\Local\Android\Sdk\licenses
Warning: License for package Android SDK Platform 28 not accepted.
复制代码
上网一查,原来是没有赞成相关协议。咱们来到C:\Users\Jiang.Wenbin\AppData\Local\Android\Sdk\tools\bin
目录下运行命令行,输入sdkmanager --licenses
,而后就会弹出一堆协议,没办法,无脑输入y
赞成吧。
再次运行cordova run android
,发现了新的报错信息:
No target specified and no devices found, deploying to emulator
No emulator images (avds) found.
1. Download desired System Image by running: "C:\Users\Jiang.Wenbin\AppData\Local\Android\Sdk\tools\android.bat" sdk
2. Create an AVD by running: "C:\Users\Jiang.Wenbin\AppData\Local\Android\Sdk\tools\android.bat" avd
HINT: For a faster emulator, use an Intel System Image and install the HAXM device driver
复制代码
能够看到,是没有找到设备的缘由。须要将手机链接到PC
,而且打开开发者选项,容许USB
调试。再次尝试,已经能够看到界面了。
咱们来试试调用一些原生API
,好比调用原生Dialog
, 调用相机等。咱们先试下Dialog
。
首先须要插件:
cordova plugin add cordova-plugin-dialogs
复制代码
接着咱们在deviceready
事件以后调用Dialog
document.addEventListener('deviceready', onDeviceReady, false);
function onDeviceReady() {
navigator.notification.alert(
'欢迎欢迎!', // message
alertDismissed, // callback
'试下Dialog', // title
'好的' // buttonName
);
}
function alertDismissed() {
// 点击按钮后的回调
}
复制代码
调试后发现弹出的中文乱码了,须要在index.html
加个meta
<meta charset="UTF-8">
复制代码
接着咱们试下调用相机,首先也是安装插件:
cordova plugin add cordova-plugin-camera
复制代码
尝试调用相机拍照,并将获得的照片经过img
元素显示出来:
// Application Constructor
initialize: function() {
const _this = this;
document.addEventListener('deviceready', this.onDeviceReady.bind(this), false);
// 点击按钮打开相机
document.querySelector('#btnOpenCamera').addEventListener('click', function() {
_this.openCamera()
})
},
openCamera: function() {
const cameraOptions = {
// 默认输出格式为base64
destinationType: Camera.DestinationType.DATA_URL,
// 输出png格式
encodingType: Camera.EncodingType.PNG
};
navigator.camera.getPicture(cameraSuccess, cameraError, cameraOptions);
// 相机拍照成功
function cameraSuccess(base64Str) {
console.log(base64Str)
// 给图片元素赋值src
document.querySelector('#captureImg').src = prefixBase64PNG(base64Str)
}
function cameraError(err) {
console.error(err)
}
function prefixBase64PNG(base64Str) {
return 'data:image/png;base64,' + base64Str;
}
}
复制代码
效果以下:
还没钱买IOS
设备,尴尬。。。
扫一扫下方小程序码或搜索Tusi博客
,即刻阅读最新文章!