使用android studio将h5项目打包成安卓app
android studio 2021.2.1
android 11
首先下载安装 android studio
创建项目,选择 Empty Activity。
app图标与名称
制作五组图标,每一对包含方的和圆的,五对是对于不同的分辨率手机。图标的名字不用改。
每新建一个项目里面都会自带默认图标,我们可以将其换掉,目录在app\src\main\res
下面的mipmap-hdpi, mipmap-mdpi, mipmap-xhdpi, mipmap-xxhdpi, mipmap-xxxhdpi
目录。在编辑器中则是res/mipmap
如果你的图标文件名称不是ic_launcher 或 ic_launcher_round
,那么就需要在app/manifests/AndroidManifests.xml
中修改两个地方 icon
和 roundIcon
默认app的名称就是项目的名称,如果需要修改app的名称,在res/values/strings.xml
将app_name
这个标签的值改为你应用的名称,比如此处改为H5ToApp2
。strings.xml
这个文件就是k-v键值对的设置,然后在其他地方被引用。
模拟运行
点击run按钮,如果提示 no device,则选择 device manager,创建一个virtual模拟器,类型为 phone
根据提示点击,如果没有下载android,得点击downloan下在。
第一次运行会比较慢。
中间按钮是回到桌面,在桌面,按住鼠标向上移动,拉起应用列表。
在使用过程中发现两个问题,一个是老是弹出system ui isn't responding
,另一个就是缓存比较严重,尤其是开了多个项目,点击Device Manager
找到对应的设备,点击右边的倒三角,Delete
,然后重新创建一个虚拟器。
app启动页
点击app之后到进入app这之间的过度时间叫做启动页,启动页放上一个图片即可,放到res/drawable
里面,文件名小写字母或数字。图片一般是1080*1920的jpg。此处为 startimage.jpg
。
添加一个控制器SplashActivity
,代码为
public class SplashActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_splash);new Thread(new Runnable() {@Overridepublic void run() {try {Thread.sleep(3000);Intent it = new Intent(getApplicationContext(), MainActivity.class);startActivity(it);finish();//关闭当前活动} catch (Exception e) {e.printStackTrace();}}}).start();}}
添加布局文件activity_splash.xml
<ImageViewandroid:id="@+id/imageView"android:layout_width="match_parent"android:layout_height="match_parent"android:visibility="visible"app:srcCompat="@drawable/startimage"tools:visibility="visible" />
在res/values/themes/themes.xml
里面添加一个style
,这里还需要设置全屏。代码为
<resources xmlns:tools="http://schemas.android.com/tools"><!-- Base application theme. --><style name="Theme.H5ToApp3" parent="Theme.MaterialComponents.DayNight.DarkActionBar"><!-- Primary brand color. --><item name="colorPrimary">@color/purple_500</item><item name="colorPrimaryVariant">@color/purple_700</item><item name="colorOnPrimary">@color/white</item><!-- Secondary brand color. --><item name="colorSecondary">@color/teal_200</item><item name="colorSecondaryVariant">@color/teal_700</item><item name="colorOnSecondary">@color/black</item><!-- Status bar color. --><item name="android:statusBarColor">@color/mainStatusBarColor</item><!-- Customize your theme here. --><item name="android:fitsSystemWindows">true</item><item name="windowNoTitle">true</item></style><style name="Theme.Splash" parent="Theme.AppCompat.Light.NoActionBar"><item name="android:windowFullscreen">true</item></style>
</resources>
修改AndroidManifest.xml
设置控制器属性,将SplashActivity
设置为 MAIN,然后设置LunchActivity
的style,代码为
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"package="com.example.h5toapp3"><applicationandroid:allowBackup="true"android:dataExtractionRules="@xml/data_extraction_rules"android:fullBackupContent="@xml/backup_rules"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:roundIcon="@mipmap/ic_launcher_round"android:supportsRtl="true"android:theme="@style/Theme.H5ToApp3"android:usesCleartextTraffic="true"tools:targetApi="31"><activityandroid:name=".MainActivity"android:theme="@style/Theme.H5ToApp3"android:exported="true"></activity><activityandroid:name=".SplashActivity"android:theme="@style/Theme.Splash"android:exported="true"><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>
https://blog.csdn.net/qq_36455052/article/details/78429713
https://www.jianshu.com/p/7e2983b65ead
https://www.jianshu.com/p/96f0b9a971ac
app添加webview
在layout/activity_main.xml
中注释掉TextView
然后添加
<WebViewandroid:id="@+id/wv_webview"android:layout_width="match_parent"android:layout_height="match_parent" />
然后在MainActivity
中修改
public class WebViewActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);//获得控件WebView webView = findViewById(R.id.wv_webview);//访问网页webView.loadUrl("http://www.baidu.com");//系统默认会通过手机浏览器打开网页,为了能够直接通过WebView显示网页,则必须设置webView.setWebViewClient(new WebViewClient(){@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) {//使用WebView加载显示urlview.loadUrl(url);//返回truereturn true;}});}
}
主界面中需要修改顶部状态栏的颜色以及其字体的颜色。修改状态栏背景色比较容易,但是修改状态栏文字的颜色比较麻烦,分为安卓原生系统,小米系统,魅族系统。
开启网络权限
修改AndroidManifest.xml
,在application
中添加android:usesCleartextTraffic="true"
,然后在</manifest>
之前加上<uses-permission android:name="android.permission.INTERNET" />
打包APK
Build --> Build Bundle(s) / APK(s) --> Build APK(s)
apk保存在app/release
目录下
使用android studio将h5项目打包成安卓app相关推荐
- vue项目打包成安卓app
创建cordova项目 cordova create folkmusic com.music.folkmusic musicapp 将新增项目中的www替换成vue打包出来的build文件 例如:co ...
- 前端VUE项目打包成安卓APP
1.打包vue项目,在项目的根目录执行命令 npm run build,直至项目打包完成 打开dist文件件,里面有一个index.html和static文件夹. 2.新建cordova项目 2.1安 ...
- web项目打包成Native App
web项目打包成Native App 好长时间没有写过博客了,闲暇时分静下心来给大家分享一下web项目打包成Native App的小知识,最近公司的web项目都开发到收尾阶段了,也在把web项目打包成 ...
- app vue 真机运行_使用 HBuilder 将 Vue 项目打包成手机 App
在开发移动端 app 时可以选择原生 app 和 webapp, 原生 app 体验好,开发成本高,相对的 webapp 体验要差,开发成本低.webapp 要求很低,可以说只要会开发web 站就能开 ...
- 使用uni-app把h5网页封装成安卓app
文章目录 简介 创建一个uni-app项目 使用web-view组件 设置内嵌的页面高度为100% 运行测试 去除title元素 发布安卓app 简介 uni-app 是一个使用 Vue.js 开发所 ...
- python程序打包成安卓app教程_Python zipapp打包教程(超级详细)
经过复杂的开发.调试之后,终于得到一个 Python 程序,这个程序或许精巧,或许有些古拙,但它是我们心血的结晶,我们当然希望将这个程序发布出来. Python 提供了一个 zipapp 模块,通过该 ...
- Python Kivy打包成安卓App
Kivy官方提供了打包工具buildozer,该工具使用十分简便,其内部实际上是使用python-to-android完成的. 但是这个工具目前只能在Linux系统上使用,因此对于windows用户, ...
- cordova 支付_Cordova打包教程(H5项目打包成ipa)
系统平台 Mac OS 使用工具 Xcode Node.js(点击Installer进行下载并安装) Mac系统终端 生成Xocde工程步骤 1,在Node.js安装完成后,打开终端,手动输入命令行来 ...
- 如何把 Kitten编程猫上开发出来的项目打包成安卓平台上可以安装的apk文件
我们使用 Kitten编程猫这款少儿编程工具,开发出来的项目,另存成本地工程文件,格式为bcm: bcm文件打开可以发现,内容是json格式的明文数据,包含了该项目内使用到的scene(场景),素材( ...
最新文章
- 通过 cygwin64 自己编译对应的 Tera Term cyglaunch.exe
- java序列化和反序列化工具_Java 序列化和反序列化工具类并解决StreamCorruptedException问题 | 学步园...
- java 跨域上传_java后台图片跨域上传图片 文件
- 累加器A用c语言,累加器A的主要作用是什么_一文解析累加器a和acc的区别
- day25 java的集合(3)List
- Netty工作笔记0077---handler链调用机制实例4
- @SuppressWarnings注解的详解
- php随机生成卡密,PHP随机生成不反复的8位卡号(数字)和卡密(字符串)_后端开发...
- 一文吃透strcmp函数
- android版直播伴侣,来疯直播伴侣
- php office 在线预览,在线预览pdf和Office文档
- 电脑计算机怎么显示到桌面,怎么显示我的电脑到桌面
- 微信查询对账单对账+数据读取解析入库
- 无人机DLG生产作业流程
- mybatis系列一:入门篇
- python reset_在python中创建'reset'方法以重置已编辑的字符串
- Linux系列 使用vi文本编辑器
- Revit二开:控制视图的细线模式
- python解决换零钱问题_多种解法解决“零钱兑换”问题
- 落单的数(Java)