写一次代码,运行在所有移动平台

abloz 2012-04-26
2012-04-26

http://abloz.com author:周海汉 date:2012.4.26

ios,android,windows phone,symbian四个主流移动平台,代码相差较大,往往需要几套人马来开发各不同平台的内容。一直想,如果有一个类似网页开发的平台,开发一次,就像应用一样在各不同智能手机上运行,那该多好! 正好有这么一个项目,Apache 的哥多华(cordova)平台下的phonegap,可以满足这样的期望。而且还超出期望,除了支持上述四个主流智能平台,还支持black berry,hp的webos,甚至三星的基于linux的bada移动平台。而且能生成各平台独立的安装程序,可以在各大应用市场上进行推广。

先在android平台上来个hello word试试! 准备: 平台准备: eclipse j2ee版本, 安装最新版android sdk, 安装最新eclipse android开发插件ADT, 下载最新的phonegap开发包。 我下的是phonegap-phonegap-1.7.0rc1-0-g1564354.zip

安装phonegap 启动Eclipse,然后在菜单“File”下选择新建android项目,取名hellopgap 在生成的项目根目录下建 /libs /assets/www 两个目录 将解压的phonegap的libandroid下的cordova-1.7.0rc1.js拷贝到/assets/www 将xml目录拷贝到hellopgap下的/res目录 将cordova-1.7.0rc1.jar拷贝到/libs下面 刷新eclipse项目,将libs下的cordova-1.7.0rc1.jar,add to build path

代码修改 根据不同的phonegap版本,可能不完全一样。 到2012.4.26最新的代码修改方法:

修改com.abloz.hellogap下的HellopgapActivity.java 注释import android.app.Activity 增加import org.apache.cordova.*; 将Activity改为DroidGap 注释setContentView(R.layout.main); 增加 super.loadUrl(“file:///android_asset/www/index.html”); 如下所示:



    
    package com.abloz.hellogap;
    
    //import android.app.Activity;
    import android.os.Bundle;
    import org.apache.cordova.*;
    public class HellopgapActivity extends DroidGap {
        /** Called when the activity is first created. */
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            super.loadUrl("file:///android_asset/www/index.html");
            //setContentView(R.layout.main);
        }
    }



在/assets/www下新建index.html 复制如下代码:



    
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE html>
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
        <title>你好,世界!</title>
        <meta name="author" content="周海汉" />
    	<script type="text/javascript" charset="utf-8" src="cordova-1.7.0rc1.js"></script>
    </head>
    <body>
    <h1>你好,移动世界!</h1>
    </body>
    </html>


你好,移动世界!


修改 AndroidManifest.xml 增加



    
    <supports-screens
    android:largeScreens="true"
    android:normalScreens="true"
    android:smallScreens="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.READ_PHONE_STATE" />
    <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.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" />





    
           <activity android:name="org.apache.cordova.DroidGap" android:label="@string/app_name" android:configChanges="orientation|keyboardHidden">
    		<intent-filter> </intent-filter>
    	   </activity>
        </application>



并修改第一个Activity的属性,增加 android:configChanges=”orientation|keyboardHidden” 最终如下:



    
    <?xml version="1.0" encoding="utf-8"?>
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.abloz.hellogap"
        android:versionCode="1"
        android:versionName="1.0" >
     <supports-screens
    android:largeScreens="true"
    android:normalScreens="true"
    android:smallScreens="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.READ_PHONE_STATE" />
    <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.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-sdk android:minSdkVersion="10" />
    
        <application
            android:icon="@drawable/ic_launcher"
            android:label="@string/app_name" >
            <activity
                android:name=".HellopgapActivity"
                android:label="@string/app_name"
                android:configChanges="orientation|keyboardHidden"
                >
                <intent-filter>
                    <action android:name="android.intent.action.MAIN" />
    
                    <category android:name="android.intent.category.LAUNCHER" />
                </intent-filter>
            </activity>
           <activity android:name="org.apache.cordova.DroidGap" android:label="@string/app_name" android:configChanges="orientation|keyboardHidden">
    		<intent-filter> </intent-filter>
    	   </activity>
        </application>
    
    </manifest>



运行 在项目上右键,运行为android application,会在模拟器或手机中看到全屏的Hello world几个打字。 并且bin下也生成了hellopgap.apk。这是我的google galaxy nexus上运行的画面: 参考: 下载:http://phonegap.com/download 入门示例:http://phonegap.com/start 源代码:https://github.com/phonegap/phonegap 中文网站:http://www.phonegap.cn 阿帕奇哥多华平台:http://incubator.apache.org/cordova/


如非注明转载, 均为原创. 本站遵循知识共享CC协议,转载请注明来源