利用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中 ...
随机推荐
- springboot-vue项目前台2
api_account.js import * as API from './' export default { //登录 login: params => { return API.POST ...
- centos中安装php7
centos7下安装php7 php7 centos7 安装PHP7 首先安装一些必须的依赖,这里就不阐述了,后面文章再细说 yum install -y \ gcc-c++ autoconf \ l ...
- git操作整理
昨天手残 然后在GitHub for windows 上点了revert 然后就给重置了 更手残的是又给同步了 . 但是 GitHub 会保留之前的版本 . 只要删掉本次修改就可. 解决方案: g ...
- linux du与ls查看文件大小时的区别
du和ls查看文件大小的区别 du == disk usage (磁盘使用量,占用的磁盘空间)du 的基本使用du -s #s参数是可以统计占硬盘空间大小的如 du -skh web-k或-- ...
- DNS 介绍
DNS 介绍 DNS 为 Domain Name System (域名系统的缩写),它是一种将ip地址转换为对应的主机名或将主机名转换成与之对应的ip地址的一种服务机制.DNS使用TCP和UDP,端口 ...
- struts2数据类型转换详解
Web应用程序的交互都是建立在HTTP之上的,互相传递的都是字符串.也就是说服务器接收到的来自用户的数据只能是字符串或者是字符数组,而在Web应用的对象中,往往使用了多种不同的类型,如整数(int). ...
- 监控pbs运行状况
# 监控内存使用情况 job_id=163997workdir=/share_bio/echo "population_sizes" >> $workdir/pbs/p ...
- EntityFramework 学习 一 Colored Entity in Entity Framework 5.0
You can change the color of an entity in the designer so that it would be easy to see related groups ...
- URL重写技术总结
URL重写技术总结 概要:什么是url重写? URL 重写是截取传入 Web 请求并自动将请求重定向到其他 URL 的过程.比如浏览器发来请求 hostname/101.html ,服务器自动将这个请 ...
- JavaScript中有时候需要获取当前的时间戳
JavaScript中有时候需要获取当前的时间戳信息,下面列举了三种获取当前时间戳的方法,第一种方法只精确到秒,后两种方法精确到毫秒. 第一种方法 var timestamp1 = Date.pars ...