利用HTML5开发Android笔记(下篇)
资源来自于www.mhtml5.com 杨丰盛老师成都场的PPT分享 一个很简明的demo 可以作为入门基础
学习的过程中做了点笔记 整理如下 虽然内容比较简单 但是数量还是比较多的 所以分了3篇
(上)包括Android设备多分辨率的问题,Android中构建HTML5应用程序基础
(中)包括Android与JS之间的互动,Android处理JS的警告对话框等,Android中的调试
(下)包括本地储存在Android中的应用,地理位置的应用,离线应用的构建
—————————————————————————————— 分割线 ————————————————————————————————————————
进入正题
● HTML5本地存储在Android中的应用
HTML5提供了2种客户端存储数据新方法:
localStorage 没有时间限制
sessionStorage 针对一个Session的数据存储
- <script type="text/javascript">
- localStorage.lastname="Smith";
- document.write(localStorage.lastname);
- </script>
- <script type="text/javascript">
- sessionStorage.lastname="Smith";
- document.write(sessionStorage.lastname);
- </script>
WebStorage的API:
- //清空storage
- localStorage.clear();
- //设置一个键值
- localStorage.setItem(“yarin”,“yangfegnsheng”);
- //获取一个键值
- localStorage.getItem(“yarin”);
- //获取指定下标的键的名称(如同Array)
- localStorage.key(0);
- //return “fresh” //删除一个键值
- localStorage.removeItem(“yarin”);
- 注意一定要在设置中开启哦
- setDomStorageEnabled(true)
在Android中进行操作
- //启用数据库
- webSettings.setDatabaseEnabled(true);
- String dir = this.getApplicationContext().getDir("database", Context.MODE_PRIVATE).getPath();
- //设置数据库路径
- webSettings.setDatabasePath(dir);
- //使用localStorage则必须打开
- webSettings.setDomStorageEnabled(true);
- //扩充数据库的容量(在WebChromeClinet中实现)
- public void onExceededDatabaseQuota(String url, String databaseIdentifier, long currentQuota,
- long estimatedSize, long totalUsedQuota, WebStorage.QuotaUpdater quotaUpdater) {
- quotaUpdater.updateQuota(estimatedSize * 2);
- }
在JS中按常规进行数据库操作
- function initDatabase() {
- try {
- if (!window.openDatabase) {
- alert('Databases are not supported by your browser');
- } else {
- var shortName = 'YARINDB';
- var version = '1.0';
- var displayName = 'yarin db';
- var maxSize = 100000; // in bytes
- YARINDB = openDatabase(shortName, version, displayName, maxSize);
- createTables();
- selectAll();
- }
- } catch(e) {
- if (e == 2) {
- // Version mismatch.
- console.log("Invalid database version.");
- } else {
- console.log("Unknown error "+ e +".");
- }
- return;
- }
- }
- function createTables(){
- YARINDB.transaction(
- function (transaction) {
- transaction.executeSql('CREATE TABLE IF NOT EXISTS yarin(id INTEGER NOT NULL PRIMARY KEY, name TEXT NOT NULL,desc TEXT NOT NULL);', [], nullDataHandler, errorHandler);
- }
- );
- insertData();
- }
- function insertData(){
- YARINDB.transaction(
- function (transaction) {
- //Starter data when page is initialized
- var data = ['1','yarin yang','I am yarin'];
- transaction.executeSql("INSERT INTO yarin(id, name, desc) VALUES (?, ?, ?)", [data[0], data[1], data[2]]);
- }
- );
- }
- function errorHandler(transaction, error){
- if (error.code==1){
- // DB Table already exists
- } else {
- // Error is a human-readable string.
- console.log('Oops. Error was '+error.message+' (Code '+error.code+')');
- }
- return false;
- }
- function nullDataHandler(){
- console.log("SQL Query Succeeded");
- }
- function selectAll(){
- YARINDB.transaction(
- function (transaction) {
- transaction.executeSql("SELECT * FROM yarin;", [], dataSelectHandler, errorHandler);
- }
- );
- }
- function dataSelectHandler(transaction, results){
- // Handle the results
- for (var i=0; i<results.rows.length; i++) {
- var row = results.rows.item(i);
- var newFeature = new Object();
- newFeature.name = row['name'];
- newFeature.decs = row['desc'];
- document.getElementById("name").innerHTML="name:"+newFeature.name;
- document.getElementById("desc").innerHTML="desc:"+newFeature.decs;
- }
- }
- function updateData(){
- YARINDB.transaction(
- function (transaction) {
- var data = ['fengsheng yang','I am fengsheng'];
- transaction.executeSql("UPDATE yarin SET name=?, desc=? WHERE id = 1", [data[0], data[1]]);
- }
- );
- selectAll();
- }
- function ddeleteTables(){
- YARINDB.transaction(
- function (transaction) {
- transaction.executeSql("DROP TABLE yarin;", [], nullDataHandler, errorHandler);
- }
- );
- console.log("Table 'page_settings' has been dropped.");
- }
- 注意onLoad中的初始化工作
- function initLocalStorage(){
- if (window.localStorage) {
- textarea.addEventListener("keyup", function() {
- window.localStorage["value"] = this.value;
- window.localStorage["time"] = new Date().getTime();
- }, false);
- } else {
- alert("LocalStorage are not supported in this browser.");
- }
- }
- window.onload = function() {
- initDatabase();
- initLocalStorage();
- }
● HTML5地理位置服务在Android中的应用
Android中
- //启用地理定位
- webSettings.setGeolocationEnabled(true);
- //设置定位的数据库路径
- webSettings.setGeolocationDatabasePath(dir);
- //配置权限(同样在WebChromeClient中实现)
- public void onGeolocationPermissionsShowPrompt(String origin,
- GeolocationPermissions.Callback callback) {
- callback.invoke(origin, true, false);
- super.onGeolocationPermissionsShowPrompt(origin, callback);
- }
在Manifest中添加权限
- <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
- <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
HTML5中 通过navigator.geolocation对象获取地理位置信息
常用的navigator.geolocation对象有以下三种方法:
- //获取当前地理位置
- navigator.geolocation.getCurrentPosition(success_callback_function, error_callback_function, position_options)
- //持续获取地理位置
- navigator.geolocation.watchPosition(success_callback_function, error_callback_function, position_options)
- //清除持续获取地理位置事件
- navigator.geolocation.clearWatch(watch_position_id)
其中success_callback_function为成功之后处理的函数,error_callback_function为失败之后返回的处理函数,参数position_options是配置项
在JS中的代码
- //定位
- function get_location() {
- if (navigator.geolocation) {
- navigator.geolocation.getCurrentPosition(show_map,handle_error,{enableHighAccuracy:false,maximumAge:1000,timeout:15000});
- } else {
- alert("Your browser does not support HTML5 geoLocation");
- }
- }
- function show_map(position) {
- var latitude = position.coords.latitude;
- var longitude = position.coords.longitude;
- var city = position.coords.city;
- //telnet localhost 5554
- //geo fix -82.411629 28.054553
- //geo fix -121.45356 46.51119 4392
- //geo nmea $GPGGA,001431.092,0118.2653,N,10351.1359,E,0,00,,-19.6,M,4.1,M,,0000*5B
- document.getElementById("Latitude").innerHTML="latitude:"+latitude;
- document.getElementById("Longitude").innerHTML="longitude:"+longitude;
- document.getElementById("City").innerHTML="city:"+city;
- }
- function handle_error(err) {
- switch (err.code) {
- case 1:
- alert("permission denied");
- break;
- case 2:
- alert("the network is down or the position satellites can't be contacted");
- break;
- case 3:
- alert("time out");
- break;
- default:
- alert("unknown error");
- break;
- }
- }
其中position对象包含很多数据 error代码及选项 可以查看文档
● 构建HTML5离线应用
需要提供一个cache manifest文件,理出所有需要在离线状态下使用的资源
例如
- CACHE MANIFEST
- #这是注释
- images/sound-icon.png
- images/background.png
- clock.html
- clock.css
- clock.js
- NETWORK:
- test.cgi
- CACHE:
- style/default.css
- FALLBACK:
- /files/projects /projects
在html标签中声明 <html manifest="clock.manifest">
HTML5离线应用更新缓存机制
分为手动更新和自动更新2种
自动更新:
在cache manifest文件本身发生变化时更新缓存 资源文件发生变化不会触发更新
手动更新:
使用window.applicationCache
- if (window.applicationCache.status == window.applicationCache.UPDATEREADY) {
- window.applicationCache.update();
- }
在线状态检测
HTML5 提供了两种检测是否在线的方式:navigator.online(true/false) 和 online/offline事件。
在Android中构建离线应用
- //开启应用程序缓存
- webSettingssetAppCacheEnabled(true);
- String dir = this.getApplicationContext().getDir("cache", Context.MODE_PRIVATE).getPath();
- //设置应用缓存的路径
- webSettings.setAppCachePath(dir);
- //设置缓存的模式
- webSettings.setCacheMode(WebSettings.LOAD_DEFAULT);
- //设置应用缓存的最大尺寸
- webSettings.setAppCacheMaxSize(1024*1024*8);
- //扩充缓存的容量
- public void onReachedMaxAppCacheSize(long spaceNeeded,
- long totalUsedQuota, WebStorage.QuotaUpdater quotaUpdater) {
- quotaUpdater.updateQuota(spaceNeeded * 2);
- }
(完)还有一个尾巴关于canvas绘图的 不如之前记录的来的详细 就不做介绍了
利用HTML5开发Android笔记(下篇)的更多相关文章
- 利用HTML5开发Android笔记(中篇)
资源来自于www.mhtml5.com 杨丰盛老师成都场的PPT分享 一个很简明的demo 可以作为入门基础 学习的过程中做了点笔记 整理如下 虽然内容比较简单 但是数量还是比较多的 所以分了3篇 ( ...
- 利用HTML5开发Android笔记(上篇)
资源来自于www.mhtml5.com 杨丰盛老师成都场的PPT分享 一个很简明的demo 可以作为入门基础 学习的过程中做了点笔记 整理如下 虽然内容比较简单 但是数量还是比较多的 所以分了3篇 ( ...
- 利用HTML5开发Android(7)---HTML5本地存储之Database Storage
在上一篇<HTML5本地存储之Web Storage篇>中,简单介绍了如何利用localStorage实现本地存储:实际上,除了sessionStorage和localStorage外,H ...
- 利用HTML5开发Android(4)---HTML5本地存储之Web Storage
Web Storage是HTML5引入的一个非常重要的功能,可以在客户端本地存储数据,类似HTML4的cookie,但可实现功能要比cookie强大的多,cookie大小被限制在4KB,Web Sto ...
- 利用HTML5开发Android(6)---构建HTML5离线应用
需要提供一个cache manifest文件,理出所有需要在离线状态下使用的资源例如 Manifest代码 CACHE MANIFEST #这是注释 images/sound-icon.png ima ...
- 利用HTML5开发Android(5)---HTML5地理位置服务在Android中的应用
Android中 Java代码 //启用地理定位 webSettings.setGeolocationEnabled(true); //设置定位的数据库路径 webSettings.setGeoloc ...
- 利用HTML5开发Android
● Android设备多分辨率的问题 Android浏览器默认预览模式浏览 会缩小页面 WebView中则会以原始大小显示 Android浏览器和WebView默认为mdpi.hdpi相当于mdpi的 ...
- 【转】利用HTML5开发Android
● Android设备多分辨率的问题 Android浏览器默认预览模式浏览 会缩小页面 WebView中则会以原始大小显示 Android浏览器和WebView默认为mdpi.hdpi相当于mdpi的 ...
- 利用HTML5开发Android(2)---Android中构建HTML5应用
使用WebView控件 与其他控件的使用方法相同 在layout中使用一个<WebView>标签 WebView不包括导航栏,地址栏等完整浏览器功能,只用于显示一个网页 在WebView中 ...
随机推荐
- OSI参考模型与排错
OSI参考模型中底层为其上层服务,因此排除网络故障应该也从底层到高层依次排查. 首先检查网络连接是否正常(物理层检查).例如网卡没有接好网线,将会看到带红叉的本地连接,属于物理层故障. 连接好网卡后, ...
- Python基础(16)_面向对象程序设计(类、继承、派生、组合、接口)
一.面向过程程序设计与面向对象程序设计 面向过程的程序设计:核心是过程,过程就解决问题的步骤,基于该思想设计程序就像是在设计一条流水线,是一种机械式的思维方式 优点:复杂的问题的简单化,流程化 缺点: ...
- Socke---转
Socket,又称为套接字,Socket是计算机网络通信的基本的技术之一.如今大多数基于网络的软件,如浏览器,即时通讯工具甚至是P2P下载都是基于Socket实现的.本文会介绍一下基于TCP/IP ...
- RTC是DS1339,驱动采用的是rtc-ds1307.c
我的外部RTC是DS1339,驱动采用的是rtc-ds1307.c在内核里选上了 <*> I2C support 以及 [*] Set system time from RTC on ...
- 12个提问频率最高的php面试题
你是否正在准备寻找一份PHP开发的工作,并且也在寻找一些关于PHP的面试题及答案?本文为大家分享了一些被提问频率最高的11个PHP面试题,以及对应的常规回答,每个公司都有自己的面试标准,面试和问题是完 ...
- 20145231《Java程序设计》第二次实验报告
实验二 Java面向对象程序设计 实验内容 初步掌握单元测试和TDD: 理解并掌握面向对象三要素: 初步掌握UML建模: 熟悉S.O.L.I.D原则: 了解设计模式: 实验要求 实现并体会例子中代码的 ...
- Android系统--Binder系统具体框架分析(一)补充
Android系统--Binder系统具体框架分析(一)补充 补充:对Binder驱动分析一的代码补充,添加saygoobye和saygoodbye_to服务 test_server.h #ifnde ...
- maven 安装、运行、获取帮助 —— maven权威指南学习笔记(二)
这部分在网上很容易找到详细教程,这里就略写了. 基础:系统有配置好的jdk,通过 命令行 java -version,有类似下面的提示,表示java环境以配好 下载maven:官网 http://ma ...
- 算法总结之 构造数组MaxTree
一个数组的MaxTree定义如下: 数组必须没有重复元素 MaxTree是一颗二叉树,数组的每一个值对应一个二叉树的节点 包括MaxTre树在内且在其中的每一颗子树上,值最大的节点都是树的头 给定一个 ...
- 【P2422】良好的感觉(单调栈优化DP//奇怪的暴力)
话说正解是单调栈优化DP,然而貌似根据某种玄学的推算,这个题暴力出解貌似也是可以的.首先,我们枚举所有的点作为最小点,然后横向展开,遇到更小的就停止...然后再操作一下,看上去时间O(N^2),然而由 ...