百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

2个将HTML5打包成app的方法

myzbx 2025-01-02 17:52 14 浏览

越来越多的开发者热衷于使用html5+JavaScript开发移动Web App。不过,HTML5 Web APP的出现能否在未来取代移动应用,就目前来说,还是个未知数。那么,有什么办法,既可以使用HTMl5开发应 用,又可以将其简单封装成APK文件呢?

一、Android SDK中的WebView

1.在要Activity中实例化WebView组件:WebView webView = new WebView(this);

2.调用WebView的loadUrl()方法,设置WevView要显示的网页:

? 互联网用:webView.loadUrl("http://www.qietu.com");

? 本地文件用:webView.loadUrl("file:///android_asset/XX.html"); 本地文件存放在:assets 文件中

3.调用Activity的setContentView( )方法来显示网页视图

4.用WebView点链接看了很多页以后为了让WebView支持回退功能,需要覆盖覆盖Activity类的onKeyDown()方法,如果不做任何处理,点击系统回退剪键,整个浏览器会调用finish()而结束自身,而不是回退到上一页面

5.需要在AndroidManifest.xml文件中添加权限,否则会出现Web page not available错误。

? <uses-permission android:name="android.permission.INTERNET" />

缺点:如果是载入的是普通网页,没有什么问题,但如果是html5,封装后,在android2.3以上才能正常访问,android2.2及以下,SDK中的WebView还没完全支持HTML5

下面是具体例子:

MainActivity.java

??? package com.android.webview.activity; ?

??? import android.app.Activity; ?

??? import android.os.Bundle; ?

??? import android.view.KeyEvent; ?

??? import android.webkit.WebView; ?

??? public class MainActivity extends Activity { ?

??????? private WebView webview; ?

??????? @Override

??????? public void onCreate(Bundle savedInstanceState) { ?

??????????? super.onCreate(savedInstanceState); ?

??????????? //实例化WebView对象 ?

??????????? webview = new WebView(this); ?

??????????? //设置WebView属性,能够执行Javascript脚本 ?

??????????? webview.getSettings().setJavaScriptEnabled(true); ?

??????????? //加载需要显示的网页 ?

??????????? webview.loadUrl("http://www.qietu.com/"); ?

??????????? //设置Web视图 ?

??????????? setContentView(webview); ?

??????? } ?

??????? @Override

??????? //设置回退 ?

??????? //覆盖Activity类的onKeyDown(int keyCoder,KeyEvent event)方法 ?

??????? public boolean onKeyDown(int keyCode, KeyEvent event) { ?

??????????? if ((keyCode == KeyEvent.KEYCODE_BACK) && webview.canGoBack()) { ?

??????????????? webview.goBack(); //goBack()表示返回WebView的上一页面 ?

??????????????? return true; ?

??????????? } ?

??????????? return false; ?

??? }

在AndroidManifest.xml文件中添加权限

??? <?xml version="1.0" encoding="utf-8"?>

??? <manifest xmlns:android="http://schemas.android.com/apk/res/android"

????????? package="com.android.webview.activity"

????????? android:versionCode="1"

????????? android:versionName="1.0">

??????? <uses-sdk android:minSdkVersion="10" />

??????? <application android:icon="@drawable/icon" android:label="@string/app_name">

??????????? <activity android:name=".MainActivity"

????????????????????? android:label="@string/app_name">

??????????????? <intent-filter>

??????????????????? <action android:name="android.intent.action.MAIN" />

??????????????????? <category android:name="android.intent.category.LAUNCHER" />

??????????????? </intent-filter>

??????????? </activity>

??????? </application>

??????? <uses-permission android:name="android.permission.INTERNET"/>

??? </manifest>

二、使用PhoneGap

??? PhoneGap是一个用基于HTML,CSS和JavaScript的,创建移动跨平台移动应用程序的快速开发平台。它使开发者能够利用 iPhone,Android,Palm,Symbian,WP7,Bada和Blackberry智能手机的核心功能——包括地理定位,加速器,联系 人,声音和振动等,此外PhoneGap拥有丰富的插件,可以以此扩展无限的功能。PhoneGap是免费的,但是它需要特定平台提供的附加软件,例如 iPhone的iPhone SDK,Android的Android SDK等,

详细方法请见:http://phonegap.com/start#android

优点:在Eclipse中加入SDK,编程自由,完美适应不同设备屏幕大小,适合高手使用。

缺点:没有使用布局,直接加载网页,不能添加广告。

----------------

切图网(qietu.com)最早将psd转html服务模式带到国内,并首个提供响应式、webapp前端开发的公司。专注web前端开发技术,关注用户体验,加我们公众微信账号:qietuwang(长按复制)

相关推荐

HTML5学习笔记-绘制变形图形之组合效果

绘制组合效果的图形将一个图形绘制在另一个图形之上,图形效果会受制于图形的绘制顺序,可利用globalCompositeOperation属性组合图形,前面绘制贝塞尔曲线时,我就已经用过这个属性了,绘制...

安卓自定义 View 进阶:贝塞尔曲线(上)

在上一篇文章Path之基本图形中我们了解了Path的基本使用方法,本次了解Path中非常非常非常重要的内容-贝塞尔曲线。一.Path常用方法表为了兼容性(偷懒)本表格中去除了在API21(即安卓...

使用Python绘制迷人的二维心形曲线和三维马鞍面

Python是一个功能强大的编程语言,不仅可以处理数据分析和机器学习任务,还能够创建美观的图形和图像。在这篇博客中,我们将学习如何使用Python的matplotlib库和PyQt5框架来绘制二维心形...

年度最爱的朋友圈封面,太好玩了吧

哈喽~大家早上好呀!不知道大家有没有这种想法:我可以不发朋友圈,但我会换上自己喜欢又好看的朋友圈封面、头像或者签名。而最近我就发现了一个超火的涂鸦玩法,简直实现了朋友圈创作自由~再也不用去网上找这些有...

两英寸中的沿途风景(两英寸有多高?)

画家DinaBrodsky将这个项目命名为“小人国自行车旅行指南”,她把自己长达10年的骑行所见记忆,几乎全部浓缩在仅有两英寸直径的圆形画布上。这些作品中的景致都是真实存在的,而且完全是一个骑行者眼...

小白也能学会的Q萌插画头像教程,再也不怕撞头像了

你有没有这样的烦恼呢?想学插画,买了iPad,安装了Procreate,结果找不到教程,不会画,连最简单的头像也画不出来,这可咋办?别慌!今天同年美术就来教大家用Procreate画超简单的Q萌头像。...

篮球元素创意logo设计(篮球元素创意logo设计理念)

在三维空间与二维平面交汇处,篮球标志设计演绎着独特的视觉辩证法。这项运动特有的力学轨迹、集体意志与文化基因,在圆形画布上构建出超越图形本身的能量场域。当设计师的思维触角穿透表象的运动符号,触及篮球运动...

高颜来袭!假如井盖会说话,假如墙壁有生命

一群人在地上、墙上涂涂画画,竟然是在上课?没错!一直以来,东北林业大学的手绘创作与文化课以其独特趣味性和实践性深受大家喜爱,可谓一课难求。在这门课上,同学们化身“神笔马良”,用画笔勾勒世界,将粉墨挥洒...

画布上的玉色缪斯:詹姆斯·桑特笔尖的永恒柔光

詹姆斯·桑特(JamesSant),一位在英国维多利亚时代享有盛誉的肖像画家,他的艺术生涯跨越了19世纪的大部分时间,从1820年出生至1916年离世,见证了英国艺术史的辉煌篇章。桑特不仅以其精湛的...

可变数据打印软件如何制作圆形标签序列号

今天给小伙伴们分享一下在可变数据打印软件中是如何制作圆形标签序列号的具体制作步骤的哦。在可变数据打印软件中制作标签的大致步骤是先设置标签纸张大小,在绘制标签内容,标签制作完成,点击软件打印预览,预览没...

伞上绘梦:小艺术家们的创意绽放——阜阳阜南三小手绘伞主题活动

运营总监:鲍安常LJ0072025年4月7日整理操场上,彩笔沙沙学生们围坐,笑语喧哗透明雨伞静静躺下等一场春天的魔法画笔不停,梦想在挥洒伞面成了春天的家待雨落下,撑起它让春天,在伞中开遍天涯在阜南三小...

《photoshop教程》ps设计圆形色彩相位图效果图

本文教大家用PS画色轮图,色轮图就是色彩相位图,它完整表现了色相环360度的全部颜色,PS的色相/饱和度命令依据色轮图而设计,不过在色相/饱和度命令中,你看到的不是色轮,而是色轮的另一种形式--色条,...

揭秘!餐盘上那个小圆坑,99%的人用错了?

餐盘中的小圆形区域,常让人在用餐时产生好奇——这个既不像分隔格又不像装饰的凹陷,究竟有何用途?通过梳理设计历史、功能演变与大众解读,我们可以发现,这一设计不仅是实用主义的产物,更承载了饮食文化与生活智...

图片四个角怎么能做成圆弧角?这几种制作方法操作起来很简单!

图片四个角怎么能做成圆弧角?在当今这个视觉内容爆炸的时代,图像不仅仅是信息的载体,更是情感交流的桥梁,深刻地渗透进我们的日常生活,然而,一个微妙却常被边缘化的观察是,传统图片那尖锐的直角边缘,在不经意...

标签制作软件如何快速制作圆形合格证标签

今天给小伙伴们分享一下标签制作软件中如何快速制作圆形合格证标签的具体操作步骤。这个合格证标签是一个小小的圆形,标签是带颜色的,这种标签在进行制作的时候应该怎么制作呢?接下来就一起来看下吧。我们可以看到...