phoneGap学习笔记——android+phoneGap环境搭建
来源:互联网 发布:网络机顶盒app软件排行 编辑:程序博客网 时间:2024/05/16 06:39
我之前有学过jquery mobile ,后来发现phoneGap结合jquery mobile 可以搭建跨平台的移动应用,所以出于兴趣去学习了一下phoneGap ,这个总结是在android的环境下搭建的环境:
说明:http://www.phonegapcn.com/developers/get-started-13/get-started 这里的入门教程环境搭建真是坑,不是我想黑它,是它使用的版本太旧了,现在phoneGap的版本都已经是3.4的了,这里的中文教程还是1.0的,害我浪费了一天的时间在瞎搞!还是官网www.phonegap.com的专业,这里也感谢一下phonegap社区(群号:171920628)的 “撸主”北京_youBoy 的指导,群里也有一些比较好的共享资料!
下面来讲一下搭建环境的步骤:
一、安装、配置JDK开发环境,最好是使用1.6+
1、配置JAVA_HOME、PATH、CLASSPATH环境变量
二、下载eclipse IDE 、 android SDK
官网:http://developer.android.com/sdk/index.html
下载完后:这是基本的目录结构
三、下载phoneGap
官网:http://phonegap.com/install/ 目前版本是3.4,是使用node.js来安装的,具体我也没有操作过,我这里使用的版本的是2.9.0,因为在2.9.1里面没有找到jar包,所以就使用了2.9.0版本
四、创建Android 并搭建phoneGap环境
1、启动下载好的eclipse ,直接创建android application project ,一直点下一步,创建好后,会出现这样的目录结构,
这里会生成一个appcompat_v7的java 7依赖包,此时我们的Android项目已经创建好,把phoneGap环境搭建进来
2、搭建phoneGap环境
(1) 将下载好的phone.2.9.0 中的cordova-2.9.0.jar放入/libs 目录
(2)将xml文件夹copy到/res目录下
(3)将以下代码copy到AndroidManifest.xml
<supports-screens android:largeScreens="true" android:normalScreens="true" android:smallScreens="true" android:xlargeScreens="true" android:resizeable="true" android:anyDensity="true" /> <uses-permission android:name="android.permission.CAMERA" /> <uses-permission android:name="android.permission.VIBRATE" /> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" /> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.RECEIVE_SMS" /> <uses-permission android:name="android.permission.RECORD_AUDIO" /> <uses-permission android:name="android.permission.RECORD_VIDEO"/> <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" /> <uses-permission android:name="android.permission.READ_CONTACTS" /> <uses-permission android:name="android.permission.WRITE_CONTACTS" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.GET_ACCOUNTS" /> <uses-permission android:name="android.permission.BROADCAST_STICKY" />
(4)在/assets目录下创建www文件夹,将cordova.js 复制到www文件夹下,并新建一个index.html
(5)在src目录中修改 mainactivity.java
引入import org.apache.cordova.*;
继承DroidGap
注释setContentView(R.layout.activity_main);
加上super.loadUrl("file:///android_asset/www/index.html");
最后修改结果
package com.example.hellomobile;import android.support.v7.app.ActionBarActivity;import android.support.v7.app.ActionBar;import android.support.v4.app.Fragment;import android.os.Bundle;import android.view.LayoutInflater;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.view.ViewGroup;import android.os.Build;import org.apache.cordova.*;public class MainActivity extends DroidGap {@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);//setContentView(R.layout.activity_main);super.loadUrl("file:///android_asset/www/index.html");/*if (savedInstanceState == null) {getSupportFragmentManager().beginTransaction().add(R.id.container, new PlaceholderFragment()).commit();}*/}@Overridepublic boolean onCreateOptionsMenu(Menu menu) {// Inflate the menu; this adds items to the action bar if it is present.getMenuInflater().inflate(R.menu.main, menu);return true;}@Overridepublic boolean onOptionsItemSelected(MenuItem item) {// Handle action bar item clicks here. The action bar will// automatically handle clicks on the Home/Up button, so long// as you specify a parent activity in AndroidManifest.xml.int id = item.getItemId();if (id == R.id.action_settings) {return true;}return super.onOptionsItemSelected(item);}/** * A placeholder fragment containing a simple view. */public static class PlaceholderFragment extends Fragment {public PlaceholderFragment() {}@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {View rootView = inflater.inflate(R.layout.fragment_main, container,false);return rootView;}}}
(6)最后一步,创建AVD,查看效果(AVD模拟器启动时间比较长,耐心等待)
这样就完成了环境搭建!
- phoneGap学习笔记——android+phoneGap环境搭建
- PhoneGap/Cordova学习笔记--1.Android环境搭建
- PhoneGap Android环境搭建
- PhoneGap 2.9、PhoneGap 3.4 android环境搭建
- phoneGap+android学习之搭建环境
- PhoneGap-Android开发环境搭建
- PhoneGap-Android开发环境搭建
- phoneGap-Android开发环境搭建
- phoneGap Android开发环境搭建
- phoneGap开发环境搭建(android)
- phoneGap-Android开发环境搭建
- android开发 +phonegap环境搭建
- phoneGap-Android开发环境搭建
- phoneGap之Android环境搭建
- PhoneGap环境搭建(android平台)
- phoneGap-Android开发环境搭建
- phonegap android开发环境搭建
- phoneGap+android之搭建环境
- SQL Server破坏日志备份链之后,可以通过全备,但是也可以通过差异备份来恢复日志链
- Intent的属性
- iOS 获取时间
- Java log4j的使用实例
- Spring MVC-文件上传下载
- phoneGap学习笔记——android+phoneGap环境搭建
- UDP套接字编程
- 旅途随笔
- ps 透明背景的图片
- Android中常用的工具类01
- [Java聊天室服务器]实战之三 接收循环
- 第一个hiberbate的改进
- 【原创】Ubuntu下vim配置
- IOS-表视图中添加搜索功能