zoukankan      html  css  js  c++  java
  • 第一个PhoneGap(cordova)应用

    PhoneGap是一套能让你使用HTML5轻松调用本地API接口和发布应用到商店的应用开发平台。官方说有低成本,低开发周期,轻量化等优点,这些咱暂时也没法证明,略过不表。但是有一条跨平台,却是很明显的优势。因为它采用HTML5+JavaScript的模式来开发应用。PhoneGap用JavaScript统一封装了几大平台的本地api(Andriod,IOS,WP8/7,WINRT)等等。。这样的话从一个平台移植到另外一个平台只需要把HTML代码跟JS原封不动的拿过去,打包一下就可以了。PhoneGap后来被Adobe收购,然后又贡献给了开源社区,现在由Apache管理,改名cordova。

    为了给昨天的html5画图板移植到移动设备上,我决定采用phoneGap平台,这样只要编写一边就可以多出运行了。

    今天先在Andriod下架设phoneGap环境。

    1.下载phoneGap

    http://phonegap.com/download#autodownload

    解压出来,找到lib/android目录。

    2.在eclipse下新建Andriod项目,这个跟普通项目一样。

    3.在assets目录下新建文件夹“www”

    把lib/android目录下的cordova-2.6.0.js复制到这个目录下。把cordova-2.6.0.jar复制到libs目录下。

    image

    4.在www目录下新建一个html文件index.html。我们的界面就要在这里建立了。

    image

    index的代码如下:

    <!doctype html>
    <html>
    <head>
         <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width, height=device-height, target-densitydpi=device-dpi" />
        <title>HTML5Paint</title>
        <script type="text/javascript" src="cordova-2.6.0.js" charset="utf-8"></script>
        <script type="text/javascript">
            alert("HELLO CORDOVA");
        </script>
    
    </head>
    <body>
    
    <h1>HTML5Paint</h1>
    </body>
    </html>

    5.把lib/android目录下的xml文件夹整个复制到res面目下

    image

    6.修改AndroidManifest.xml添加用户权限

    在<manifest >标签的内的最前部添加如下代码

        <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" />

    7.修改MainAcivity.java

    public class MainActivity extends DroidGap {
    
          @Override
            public void onCreate(Bundle savedInstanceState)
            {
                super.onCreate(savedInstanceState);
                super.loadUrl("file:///android_asset/www/index.html");
            }
    
    }

    8.build一下会有错误,这是因为前面的cordova-2.6.0.jar没有添加到buildpath里面去。添加buildpath。

    image

    继续build就过了。

    最后run一下:

    imageimage

    这样一个phonegap的Andriod程序就搞定了。明天把昨天的那个HTML5画板移植过来。

  • 相关阅读:
    基金定投是什么?定投的特点?
    Linux环境下MySQL 5.6安装与配置----亲测有效----纯离线安装
    OI生涯回忆录
    NOI2020游记
    Redis操作
    Redis概述
    Memcached
    动态规划——最长回文字符串
    两数之和&无重复字符最长字符串
    黑盒测试常见方法
  • 原文地址:https://www.cnblogs.com/kklldog/p/3055779.html
Copyright © 2011-2022 走看看