前两章分别对开发环境和Jquery Mobile基础知识进行了介绍,本章介绍创建一个Android项目,并使用WebView控件显示HTML数据。

首先创建一个Android Application项目,这个在第一节已经讲过,不再赘述。

然后以图的形式介绍下Android项目几个关键文件的功能。

首先是AndroidManifest.xml文件,这个文件算是最重要的XML配置文件了, 比如该项目的名称,该项目要开通哪些权限,该项目用到了哪些核心Activity类型,哪个是默认启动项。

我的AndroidManifest.xml内容如下:

Xml代码  
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"
  3. package="com.bless.blesscrm"
  4. android:versionCode="1"
  5. android:versionName="1.0" >
  6. <!-- 开启网络访问权限 -->
  7. <uses-permission android:name="android.permission.INTERNET" >
  8. </uses-permission>
  9. <uses-sdk
  10. android:minSdkVersion="8"
  11. android:targetSdkVersion="8" />
  12. <application
  13. android:name="com.bless.blesscrm.AppContext"
  14. android:allowBackup="true"
  15. android:icon="@drawable/ic_launcher"
  16. android:label="@string/app_name"
  17. android:theme="@style/AppTheme" >
  18. <activity
  19. android:name="com.bless.blesscrm.MainActivity"
  20. android:label="@string/app_name"
  21. android:screenOrientation="portrait">
  22. <intent-filter>
  23. <action android:name="android.intent.action.MAIN" />
  24. <!-- 设置当前Activity为启动项 -->
  25. <category android:name="android.intent.category.LAUNCHER" />
  26. </intent-filter>
  27. </activity>
  28. </application>
  29. </manifest>

设置中有开发网络访问权限,这样你就可以通过WebView访问外网地址信息了

com.bless.blesscrm.AppContext是一个全局类,类中的变量在任何地方都能访问

com.bless.blesscrm.MainActivity是默认启动的Activity,也就是说Android应用启动后会执行这个Activity的方法来生成对应的页面信息;

很多手机支持屏幕翻转,但是基于WebVeiw的Activity通常不要支持翻转,因为你一翻转就会重新调用Activity的onCreate方法,又回到首页了,所以在<activity>中增加一个属性android:screenOrientation="portrait"只允许竖屏显示(高度大于宽度的屏幕)

然后在src源代码目录下找到com.bless.blesscrm.MainActivity,应用启动后会执行MainActivity的onCreate方法,所以页面布局、显示等初始化内容都要在这个方法中编写。

Java代码  
  1. protected void onCreate(Bundle savedInstanceState) {
  2. userManager = (UserManager) BeanFactory.getDBManager(UserManager.class, this);
  3. super.onCreate(savedInstanceState);
  4. app = (AppContext) super.getApplication();
  5. // 初始化当前用户
  6. app.setUser(userManager.getCurrentUser());
  7. setContentView(R.layout.activity_main);
  8. webView = (WebView) findViewById(R.id.webview);
  9. init();
  10. /** javascript与Java对象映射,页面可使用javascript:ajax.xx()来调用AjaxManager的方法 */
  11. webView.addJavascriptInterface(new JavascriptUser(MainActivity.this), "javascriptUser");
  12. webView.loadUrl("file:///android_asset/www/index.html");
  13. }

setContentView(R.layout.activity_main)用于设置Android屏幕显示什么内容,而R.layout.activity_main就是内容文件,这个是一个XML,在上图中的layout文件夹下,名称为activity_main.xml,这个文件只有很简单一个WebView标签:

Xml代码  
  1. <WebView  xmlns:android="http://schemas.android.com/apk/res/android"
  2. android:id="@+id/webview"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. />

webView = (WebView) findViewById(R.id.webview)表示获取WebView对象,这个控件定义在activity_main.xml中。

webView.addJavascriptInterface(new JavascriptUser(MainActivity.this), "javascriptUser")用于给HTML页面的javascript提供一个接口支持,页面js可以通过javascriptUser.xxx()执行这个Java中的方法,这个就是页面与Android后台交互最重要的接口了!(具体怎么个调用法,在后面文章中说明)

webView.loadUrl("file:///android_asset/www/index.html");表示WebView控件初次加载哪个HTML文件,这个有个格式标准,如果以[file:///android_asset]为前缀,则可以访问Android项目下asset文件夹中的HTML文件。

init()方法定义了一些WebView的自定义配置,如下代码有详细注释,就不做解释了。

Java代码  
  1. private void init() {
  2. setting = webView.getSettings();
  3. setting.setSupportZoom(true);// 支持缩放
  4. setting.setDefaultZoom(WebSettings.ZoomDensity.FAR);// 设置初始化缩放大小
  5. setting.setJavaScriptEnabled(true); // 支持页面的javascript
  6. proDlg = new ProgressDialog(this);
  7. proDlg.setMessage("加载中,请稍后...");
  8. webView.setWebViewClient(new WebViewClient() {
  9. @Override
  10. public void onPageFinished(WebView view, String url) {
  11. // 加载页面完成
  12. proDlg.dismiss();
  13. }
  14. @Override
  15. public void onPageStarted(WebView view, String url, Bitmap favicon) {
  16. // 加载页面
  17. proDlg.show();
  18. }
  19. });
  20. webView.setWebChromeClient(new WebChromeClient() {
  21. @Override
  22. public void onProgressChanged(WebView view, int newProgress) {
  23. // 动态显示进度
  24. proDlg.setMessage("已经加载:" + newProgress + " %");
  25. }
  26. });
  27. }

最后是在assets文件夹中创建页面元素,所有的javascript、css、icon和html都放在这个下面,最好分文件存放,方便查找,别忘了放Jquery Mobile,我是将整个文件都拷贝到项目下的。


 index.html文件就不多说了,这个跟平常的html一样的,在第二章中有示例。

需要注意的是,在html的<head>标签内一定要添加下面这两句,第一句无疑问是设置编码的,第二个是表示让html占满整个移动设备屏幕,这个在网上搜搜,也有很多详细说明的!

Html代码  
  1. <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  2. <meta name="viewport" content="width=device-width, initial-scale=1">

然后启动Android应用程序,调试看看是否能够显示正确的效果。

作为新手,很可能会遇到很多问题,千万不要气馁,我也是这么过来的,当初为了出这个html报了各种奇怪的错误,通过一点点排除问题,最终终于能在移动设备中显示了。

如果你感觉你的HTML写得不正确,你可以在PC上直接访问这个HTML,然后通过浏览器调试---在移动设备上调试确实太麻烦!

你可以引用第三方的Jar包到项目的lib目录下,最好一个个引用(因为有些Jar包Android不支持),然后跑一下Android看控制台是否报错。

对于Android开发,这里说得非常肤浅,个人建议新手下载一些Android视频来看,因为很多视频的讲师都很专业,他会给你很多建设性的意见,相反看书就比较枯燥,而且无法抓住重点!

Android+Jquery Mobile学习系列(3)-创建Android项目相关推荐

  1. Android+Jquery Mobile学习系列(6)-个人信息设置

    目录导航 本节开始,进行代码的实战练习.我的这个App是管理保险客户信息的,数据采用Sqlite存储在本地手机上,第一次使用需要先登记自己的个人信息,这个功能非常简单,也无关紧要,我是拿这个练手,方便 ...

  2. Android+Jquery Mobile学习系列(8)-保单/生日提醒功能

    其实这个App基本功能早已做完,并且交给老婆试用去了.但由于最近项目要保证稳定,所以持续加班,没有时间写最后一点内容,本节也就简单截图做个说明,不详细叙述实现方式.我会把代码上传到最后一章中,有兴趣的 ...

  3. Android音视频学习系列(五) — 掌握音频基础知识并使用AudioTrack、OpenSL ES渲染PCM数据

    系列文章 Android音视频学习系列(一) - JNI从入门到精通 Android音视频学习系列(二) - 交叉编译动态库.静态库的入门 Android音视频学习系列(三) - Shell脚本入门 ...

  4. 使用jQuery Mobile和Phone Gap开发Android应用程序

    使用jQuery Mobile和Phone Gap开发Android应用程序 1. 软件准备  要进行android app的开发,当然需要准备Java, eclipse和安装Android SDK, ...

  5. Android音视频学习系列(七) — 从0~1开发一款Android端播放器(支持多协议网络拉流本地文件)

    系列文章 Android音视频学习系列(一) - JNI从入门到精通 Android音视频学习系列(二) - 交叉编译动态库.静态库的入门 Android音视频学习系列(三) - Shell脚本入门 ...

  6. Android音视频学习系列(八) — 基于Nginx搭建(rtmp、http)直播服务器

    系列文章 Android音视频学习系列(一) - JNI从入门到精通 Android音视频学习系列(二) - 交叉编译动态库.静态库的入门 Android音视频学习系列(三) - Shell脚本入门 ...

  7. Android音视频学习系列(九) — Android端实现rtmp推流

    系列文章 Android音视频学习系列(一) - JNI从入门到精通 Android音视频学习系列(二) - 交叉编译动态库.静态库的入门 Android音视频学习系列(三) - Shell脚本入门 ...

  8. Android音视频学习系列(六) — 掌握视频基础知识并使用OpenGL ES 2.0渲染YUV数据

    系列文章 Android音视频学习系列(一) - JNI从入门到精通 Android音视频学习系列(二) - 交叉编译动态库.静态库的入门 Android音视频学习系列(三) - Shell脚本入门 ...

  9. Android音视频学习系列(十) — 基于FFmpeg + OpenSL ES实现音频万能播放器

    系列文章 Android音视频学习系列(一) - JNI从入门到精通 Android音视频学习系列(二) - 交叉编译动态库.静态库的入门 Android音视频学习系列(三) - Shell脚本入门 ...

最新文章

  1. 粘包的原因分析及解决
  2. MySQL查询本周、上周、本月、上个月份数据的sql代码
  3. 测试项目:车牌检测,行人检测,红绿灯检测,人流检测,目标识别
  4. 汉诺塔 hanoi 如此简单
  5. SAP License:关于集团管控模式的几点思考
  6. #C语言#警告:隐式声明函数‘xxx’ [-Wimplicit-function-declaration]
  7. EF分组后把查询的字段具体映射到指定类里面的写法
  8. Oracle Siebel CRM技术的前景
  9. Linux作业--利用RAID技术实现磁盘阵列的管理方法
  10. 二级python试题分值_2020年12月计算机二级各考试科目题型及分值比例
  11. 修复SQL2000数据库一致性错误的语句
  12. Java复习:确定给定日期是一年的第几天
  13. 照片墙(3D立体几何)
  14. oracle 修改用户信息表,Oracle批量修改用户表table的表空间 | 学步园
  15. Java生成Excel加密
  16. 对学生创业的重新认识
  17. python | requests库基本应用
  18. C++ OpenCV视频操作之CamShift跟踪算法
  19. Ubuntu系统连接Android真机测试
  20. Python学习笔记——开发图形界面wxPython、PyQt、PySide选哪一个?

热门文章

  1. 跨年照片墙php源码,简单效果照片墙
  2. 计算机基础知识_计算机基础知识汇总
  3. 利用Java制作背单词小应用
  4. php获取xml中的数据格式_php-从xml文件获取数据
  5. 20210101:力扣第42周双周赛(上)
  6. 20190820:(leetcode习题)有效的字母异位词
  7. 机器学习篇01:在线学习的支持向量机算法学习笔记
  8. 如何linux安装apache服务器,Linux中如何安装Apache服务器
  9. php 的点代表什么意思,linux .(点)是什么意思
  10. ajax请求携带tooken_当ajax碰到token的时候