资源来自于www.mhtml5.com 杨丰盛老师成都场的PPT分享 一个很简明的demo 可以作为入门基础

学习的过程中做了点笔记 整理如下 虽然内容比较简单 但是数量还是比较多的 所以分了3篇

(上)包括Android设备多分辨率的问题,Android中构建HTML5应用程序基础

(中)包括Android与JS之间的互动,Android处理JS的警告对话框等,Android中的调试

(下)包括本地储存在Android中的应用,地理位置的应用,离线应用的构建

—————————————————————————————— 分割线 ————————————————————————————————————————

进入正题

● HTML5本地存储在Android中的应用

HTML5提供了2种客户端存储数据新方法

localStorage 没有时间限制

sessionStorage 针对一个Session的数据存储

  1. <script type="text/javascript">
  2. localStorage.lastname="Smith";
  3. document.write(localStorage.lastname);
  4. </script>
  5. <script type="text/javascript">
  6. sessionStorage.lastname="Smith";
  7. document.write(sessionStorage.lastname);
  8. </script>

WebStorage的API:

  1. //清空storage
  2. localStorage.clear();
  3. //设置一个键值
  4. localStorage.setItem(“yarin”,“yangfegnsheng”);
  5. //获取一个键值
  6. localStorage.getItem(“yarin”);
  7. //获取指定下标的键的名称(如同Array)
  8. localStorage.key(0);
  9. //return “fresh” //删除一个键值
  10. localStorage.removeItem(“yarin”);
  11. 注意一定要在设置中开启哦
  12. setDomStorageEnabled(true)

Android中进行操作

  1. //启用数据库
  2. webSettings.setDatabaseEnabled(true);
  3. String dir = this.getApplicationContext().getDir("database", Context.MODE_PRIVATE).getPath();
  4. //设置数据库路径
  5. webSettings.setDatabasePath(dir);
  6. //使用localStorage则必须打开
  7. webSettings.setDomStorageEnabled(true);
  8. //扩充数据库的容量(在WebChromeClinet中实现)
  9. public void onExceededDatabaseQuota(String url, String databaseIdentifier, long currentQuota,
  10. long estimatedSize, long totalUsedQuota, WebStorage.QuotaUpdater quotaUpdater) {
  11. quotaUpdater.updateQuota(estimatedSize * 2);
  12. }

JS中按常规进行数据库操作

  1. function initDatabase() {
  2. try {
  3. if (!window.openDatabase) {
  4. alert('Databases are not supported by your browser');
  5. } else {
  6. var shortName = 'YARINDB';
  7. var version = '1.0';
  8. var displayName = 'yarin db';
  9. var maxSize = 100000; // in bytes
  10. YARINDB = openDatabase(shortName, version, displayName, maxSize);
  11. createTables();
  12. selectAll();
  13. }
  14. } catch(e) {
  15. if (e == 2) {
  16. // Version mismatch.
  17. console.log("Invalid database version.");
  18. } else {
  19. console.log("Unknown error "+ e +".");
  20. }
  21. return;
  22. }
  23. }
  24. function createTables(){
  25. YARINDB.transaction(
  26. function (transaction) {
  27. transaction.executeSql('CREATE TABLE IF NOT EXISTS yarin(id INTEGER NOT NULL PRIMARY KEY, name TEXT NOT NULL,desc TEXT NOT NULL);', [], nullDataHandler, errorHandler);
  28. }
  29. );
  30. insertData();
  31. }
  32. function insertData(){
  33. YARINDB.transaction(
  34. function (transaction) {
  35. //Starter data when page is initialized
  36. var data = ['1','yarin yang','I am yarin'];
  37. transaction.executeSql("INSERT INTO yarin(id, name, desc) VALUES (?, ?, ?)", [data[0], data[1], data[2]]);
  38. }
  39. );
  40. }
  41. function errorHandler(transaction, error){
  42. if (error.code==1){
  43. // DB Table already exists
  44. } else {
  45. // Error is a human-readable string.
  46. console.log('Oops.  Error was '+error.message+' (Code '+error.code+')');
  47. }
  48. return false;
  49. }
  50. function nullDataHandler(){
  51. console.log("SQL Query Succeeded");
  52. }
  53. function selectAll(){
  54. YARINDB.transaction(
  55. function (transaction) {
  56. transaction.executeSql("SELECT * FROM yarin;", [], dataSelectHandler, errorHandler);
  57. }
  58. );
  59. }
  60. function dataSelectHandler(transaction, results){
  61. // Handle the results
  62. for (var i=0; i<results.rows.length; i++) {
  63. var row = results.rows.item(i);
  64. var newFeature = new Object();
  65. newFeature.name   = row['name'];
  66. newFeature.decs = row['desc'];
  67. document.getElementById("name").innerHTML="name:"+newFeature.name;
  68. document.getElementById("desc").innerHTML="desc:"+newFeature.decs;
  69. }
  70. }
  71. function updateData(){
  72. YARINDB.transaction(
  73. function (transaction) {
  74. var data = ['fengsheng yang','I am fengsheng'];
  75. transaction.executeSql("UPDATE yarin SET name=?, desc=? WHERE id = 1", [data[0], data[1]]);
  76. }
  77. );
  78. selectAll();
  79. }
  80. function ddeleteTables(){
  81. YARINDB.transaction(
  82. function (transaction) {
  83. transaction.executeSql("DROP TABLE yarin;", [], nullDataHandler, errorHandler);
  84. }
  85. );
  86. console.log("Table 'page_settings' has been dropped.");
  87. }
  88. 注意onLoad中的初始化工作
  89. function initLocalStorage(){
  90. if (window.localStorage) {
  91. textarea.addEventListener("keyup", function() {
  92. window.localStorage["value"] = this.value;
  93. window.localStorage["time"] = new Date().getTime();
  94. }, false);
  95. } else {
  96. alert("LocalStorage are not supported in this browser.");
  97. }
  98. }
  99. window.onload = function() {
  100. initDatabase();
  101. initLocalStorage();
  102. }

● HTML5地理位置服务在Android中的应用

Android中

  1. //启用地理定位
  2. webSettings.setGeolocationEnabled(true);
  3. //设置定位的数据库路径
  4. webSettings.setGeolocationDatabasePath(dir);
  5. //配置权限(同样在WebChromeClient中实现)
  6. public void onGeolocationPermissionsShowPrompt(String origin,
  7. GeolocationPermissions.Callback callback) {
  8. callback.invoke(origin, true, false);
  9. super.onGeolocationPermissionsShowPrompt(origin, callback);
  10. }

在Manifest中添加权限

  1. <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
  2. <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />

HTML5中 通过navigator.geolocation对象获取地理位置信息

常用的navigator.geolocation对象有以下三种方法:

  1. //获取当前地理位置
  2. navigator.geolocation.getCurrentPosition(success_callback_function, error_callback_function, position_options)
  3. //持续获取地理位置
  4. navigator.geolocation.watchPosition(success_callback_function, error_callback_function, position_options)
  5. //清除持续获取地理位置事件
  6. navigator.geolocation.clearWatch(watch_position_id)

其中success_callback_function为成功之后处理的函数,error_callback_function为失败之后返回的处理函数,参数position_options是配置项

JS中的代码

  1. //定位
  2. function get_location() {
  3. if (navigator.geolocation) {
  4. navigator.geolocation.getCurrentPosition(show_map,handle_error,{enableHighAccuracy:false,maximumAge:1000,timeout:15000});
  5. } else {
  6. alert("Your browser does not support HTML5 geoLocation");
  7. }
  8. }
  9. function show_map(position) {
  10. var latitude = position.coords.latitude;
  11. var longitude = position.coords.longitude;
  12. var city = position.coords.city;
  13. //telnet localhost 5554
  14. //geo fix -82.411629 28.054553
  15. //geo fix -121.45356 46.51119 4392
  16. //geo nmea $GPGGA,001431.092,0118.2653,N,10351.1359,E,0,00,,-19.6,M,4.1,M,,0000*5B
  17. document.getElementById("Latitude").innerHTML="latitude:"+latitude;
  18. document.getElementById("Longitude").innerHTML="longitude:"+longitude;
  19. document.getElementById("City").innerHTML="city:"+city;
  20. }
  21. function handle_error(err) {
  22. switch (err.code) {
  23. case 1:
  24. alert("permission denied");
  25. break;
  26. case 2:
  27. alert("the network is down or the position satellites can't be contacted");
  28. break;
  29. case 3:
  30. alert("time out");
  31. break;
  32. default:
  33. alert("unknown error");
  34. break;
  35. }
  36. }

其中position对象包含很多数据 error代码及选项 可以查看文档

● 构建HTML5离线应用

需要提供一个cache manifest文件,理出所有需要在离线状态下使用的资源

例如

  1. CACHE MANIFEST
  2. #这是注释
  3. images/sound-icon.png
  4. images/background.png
  5. clock.html
  6. clock.css
  7. clock.js
  8. NETWORK:
  9. test.cgi
  10. CACHE:
  11. style/default.css
  12. FALLBACK:
  13. /files/projects /projects

在html标签中声明 <html manifest="clock.manifest"> 

HTML5离线应用更新缓存机制

分为手动更新和自动更新2种

自动更新:

在cache manifest文件本身发生变化时更新缓存 资源文件发生变化不会触发更新

手动更新:

使用window.applicationCache

  1. if (window.applicationCache.status == window.applicationCache.UPDATEREADY) {
  2. window.applicationCache.update();

在线状态检测

HTML5 提供了两种检测是否在线的方式:navigator.online(true/false) 和 online/offline事件。

在Android中构建离线应用

  1. //开启应用程序缓存
  2. webSettingssetAppCacheEnabled(true);
  3. String dir = this.getApplicationContext().getDir("cache", Context.MODE_PRIVATE).getPath();
  4. //设置应用缓存的路径
  5. webSettings.setAppCachePath(dir);
  6. //设置缓存的模式
  7. webSettings.setCacheMode(WebSettings.LOAD_DEFAULT);
  8. //设置应用缓存的最大尺寸
  9. webSettings.setAppCacheMaxSize(1024*1024*8);
  10. //扩充缓存的容量
  11. public void onReachedMaxAppCacheSize(long spaceNeeded,
  12. long totalUsedQuota, WebStorage.QuotaUpdater quotaUpdater) {
  13. quotaUpdater.updateQuota(spaceNeeded * 2);
  14. }

(完)还有一个尾巴关于canvas绘图的 不如之前记录的来的详细 就不做介绍了

利用HTML5开发Android笔记(下篇)的更多相关文章

  1. 利用HTML5开发Android笔记(中篇)

    资源来自于www.mhtml5.com 杨丰盛老师成都场的PPT分享 一个很简明的demo 可以作为入门基础 学习的过程中做了点笔记 整理如下 虽然内容比较简单 但是数量还是比较多的 所以分了3篇 ( ...

  2. 利用HTML5开发Android笔记(上篇)

    资源来自于www.mhtml5.com 杨丰盛老师成都场的PPT分享 一个很简明的demo 可以作为入门基础 学习的过程中做了点笔记 整理如下 虽然内容比较简单 但是数量还是比较多的 所以分了3篇 ( ...

  3. 利用HTML5开发Android(7)---HTML5本地存储之Database Storage

    在上一篇<HTML5本地存储之Web Storage篇>中,简单介绍了如何利用localStorage实现本地存储:实际上,除了sessionStorage和localStorage外,H ...

  4. 利用HTML5开发Android(4)---HTML5本地存储之Web Storage

    Web Storage是HTML5引入的一个非常重要的功能,可以在客户端本地存储数据,类似HTML4的cookie,但可实现功能要比cookie强大的多,cookie大小被限制在4KB,Web Sto ...

  5. 利用HTML5开发Android(6)---构建HTML5离线应用

    需要提供一个cache manifest文件,理出所有需要在离线状态下使用的资源例如 Manifest代码 CACHE MANIFEST #这是注释 images/sound-icon.png ima ...

  6. 利用HTML5开发Android(5)---HTML5地理位置服务在Android中的应用

    Android中 Java代码 //启用地理定位 webSettings.setGeolocationEnabled(true); //设置定位的数据库路径 webSettings.setGeoloc ...

  7. 利用HTML5开发Android

    ● Android设备多分辨率的问题 Android浏览器默认预览模式浏览 会缩小页面 WebView中则会以原始大小显示 Android浏览器和WebView默认为mdpi.hdpi相当于mdpi的 ...

  8. 【转】利用HTML5开发Android

    ● Android设备多分辨率的问题 Android浏览器默认预览模式浏览 会缩小页面 WebView中则会以原始大小显示 Android浏览器和WebView默认为mdpi.hdpi相当于mdpi的 ...

  9. 利用HTML5开发Android(2)---Android中构建HTML5应用

    使用WebView控件 与其他控件的使用方法相同 在layout中使用一个<WebView>标签 WebView不包括导航栏,地址栏等完整浏览器功能,只用于显示一个网页 在WebView中 ...

随机推荐

  1. Mapinfo修改道路方向

    在mapinfp工具管理添加插件Reverse Line Direction,就可以修改道路方向 插件

  2. docker学习笔记1-- 用Toolbox安装Docker--介绍Docker Machine

    使用的是Docker Toolbox,非Docker for Windows 一.docker的认识与安装(windows安装) http://blog.csdn.net/tina_ttl/artic ...

  3. PAT 天梯赛 L1-038. 新世界 【水】

    题目链接 https://www.patest.cn/contests/gplt/L1-038 AC代码 #include <iostream> #include <cstdio&g ...

  4. iOS代码瘦身实践

    1 分析当前ipa的组成 一般一个ipa会包含: 1) 资源文件 本地文件:数据.配置.数据库等等 字体文件 图片资源 2)  源代码 通过生成linkmap文件,分析源代码生成的编译文件的大小.在B ...

  5. java PinYinUtils 拼音工具类

    package com.sicdt.library.core.utils; import java.util.HashSet; import java.util.Set; import net.sou ...

  6. FANCO工程机械云平台

    此系统专门为工程机械设备使用单位定制合理的生产要求,监控生产状况,快速体现产值,通过算法计算绩效等

  7. css异步加载

    <link rel="preload" href="mystyles.css" as="style" onload="thi ...

  8. C++11 里lambda表达式的学习

    最近看到很多关于C++11的文档,有些是我不怎么用到,所以就略过去了,但是lambda表达式还是比较常用的,其实最开始学习python的时候就觉得lambda这个比较高级,为什么C++这么弱.果然C+ ...

  9. 关于nginx性能优化及基本概念

    参考文章: Nginx面试中最常见的18道题:http://blog.csdn.net/liyanlei5858/article/details/77924420 Nginx性能优化指南:http:/ ...

  10. this关键字详解

    在java中,编译器会为每个对象分配一个this关键字.在代码中使用关键字可以使代码更优雅.下面我就列举一下this关键字常见的几种场景. 1.this代表当前对象调用成员变量和方法,也是用的最多的地 ...