Android 学习小记1

目录

先介绍一下Android Studio

看看常见的模板

1. No Activity

2. Empty Activity

3. Gemini API Starter

4. Basic View Activity

5. Bottom Navigation Activity

6. Empty Views Activity

7. Navigation Drawer Views Activity

8. Responsive Views Activity

9. Game Activity C++

10. Native C++

开始我们的第一个项目

manifests文件夹

java文件夹


笔者最近摸鱼Android,但是国内不少的资料实在是过时,这里笔者打算记录一下从2024年12.29开始的Android学习的旅程。

先介绍一下Android Studio

Android Studio 是用于 Android 应用程序开发的官方 IDE(集成开发环境),它基于 JetBrains 的 IntelliJ IDEA 软件。Android Studio 提供了许多出色的功能,可提高构建 Android 应用程序的效率,例如:

  • 灵活的基于 Gradle 的构建系统

  • 快速且功能丰富的模拟器

  • 混合环境,可在其中为所有 Android 设备进行开发

  • 应用更改以将代码和资源更改推送到正在运行的应用程序,而无需重新启动应用程序

  • GitHub 和代码模板集成可帮助您开发常见的应用程序功能并导入示例代码

  • 广泛的测试工具和框架

  • C++ 和 NDK 支持

内置对 Google Cloud Platform 的支持,可轻松集成 Google Cloud Messaging 和 App Engine 等。通常,当开发人员想要在 Android Studio 中创建新项目时,他/她需要选择一个项目模板,该模板由许多Activity组成

看看常见的模板

他们分别是:

  • No Activity

  • Empty Activity

  • Gemini API Starter

  • Basic View Activity

  • Bottom Navigation Activity

  • Empty Views Activity

  • Navigation Drawer Views Activity

  • Responsive Views Activity

  • Game Activity C++

  • Native C++

1. No Activity

这些则是有经验的开发者选择的架构,一般而言没有XML,也不会有任何一个Java或者是Kotlin文件,那些文件是不会自动生成的。

  • 用途:创建一个空的Android项目,不包含任何活动或UI布局。适用于那些需要完全自定义应用结构的开发者。

  • 特点:无预定义界面或元素,开发者可以从零开始构建应用的任何部分。你需要手动添加所有的活动、布局和资源文件。

  • 适用场景:适合有经验的开发者,他们已经知道自己需要什么样的架构和功能,不依赖Android Studio提供的默认模板。

2. Empty Activity

这个是大部分初学者最经常选择的架构。

  • 用途:创建一个包含一个简单活动(Activity)和一个默认布局的基础模板。这个模板为你提供了一个简单的起点,开发者可以快速开始构建应用。

  • 特点:包含一个MainActivity和一个简单的布局文件(如activity_main.xml)。它是开发中最常用的模板之一,适合那些需要快速实现一些基本功能的开发者。

  • 适用场景:适用于初学者或那些想要实现简单应用的开发者,它为开发者提供了一个干净的基础,不包含过多复杂的功能。

3. Gemini API Starter

  • 特点:包含Gemini API的基本集成代码和接口调用结构。它为开发者提供了一个与Gemini API交互的框架,简化了API调用和数据解析过程。

  • 适用场景:适用于需要使用Gemini API的开发者,如星座应用、占星应用或任何其他基于Gemini API服务的应用。

4. Basic View Activity
  • 用途:这个模板为应用提供一个简单的UI,展示基本的视图元素,如文本框、按钮、图片等。适用于需要快速展示UI的应用。

  • 特点:它的布局文件通常包含一些基础视图组件(例如TextViewButtonImageView等)。该模板重点展示如何将常见的UI元素放入活动中,简化视图的展示过程。

  • 适用场景:适用于开发简单的界面,展示静态内容或进行简单的交互操作。

5. Bottom Navigation Activity

底部导航活动会创建一个带有底部导航的新活动。我们都遇到过包含底部导航栏的应用程序。一些流行的例子包括 Instagram、WhatsApp 等。当您选择底部导航活动时,会自动创建这些文件,以下是欢迎页面:

  • 用途:为开发者提供了底部导航栏的UI设计,允许在应用的不同部分之间进行快速切换。通常适用于拥有多个页面的应用。

  • 特点:该模板内置了底部导航栏(BottomNavigationView),用户可以点击不同的菜单项来切换不同的Fragments或活动页面。适用于需要底部导航布局的应用。

  • 适用场景:适合包含多个功能模块的应用(如社交、购物或新闻应用),用户可以通过底部导航在不同的模块之间切换。

6. Empty Views Activity

这是一个很受欢迎的活动,我们在开始开发 Android 项目时经常选择此活动。它只是创建一个新的空活动。注意:请在无活动和空活动中标记阶段。在无活动中,它会创建一个新的空项目,在空活动中,它会创建一个新的空活动。

  • 用途:类似于“Empty Activity”,但该模板关注于提供一个空的视图框架,允许开发者自己逐步构建布局和UI组件。

  • 特点:模板创建后,除了Activity外不会提供任何UI元素,开发者需要手动向布局中添加View元素,如TextViewButtonRecyclerView等。它是一个完全自定义的空白视图布局。

  • 适用场景:适用于那些需要完全控制UI元素布局的开发者,或者需要创建非常个性化的界面的应用。

7. Navigation Drawer Views Activity
  • 用途:提供一个包含侧边栏(Navigation Drawer)的UI模板,适用于需要复杂菜单导航的应用。

  • 特点:该模板包括一个滑动的侧边菜单(NavigationView),用户可以通过滑动或点击菜单按钮打开该侧边栏,菜单通常包含多个选项,帮助用户在不同的界面或功能间切换。

  • 适用场景:适用于多模块的应用,尤其是需要有多个页面或功能项的应用(例如设置页面、个人中心等)。常用于社交、新闻和管理类应用。

8. Responsive Views Activity
  • 用途:该模板旨在帮助开发者创建响应式布局,确保应用在不同屏幕尺寸和设备类型(如手机、平板)上均能良好显示。

  • 特点:模板内置了一些响应式布局元素,如ConstraintLayout,并适配了不同屏幕尺寸的视图。它可能还包含drawablevalues文件夹中的资源,以便于在不同设备和分辨率下展示不同的UI效果。

  • 适用场景:适合开发需要跨多个设备和屏幕尺寸的应用,尤其是那些需要高度适配的应用(如平板和手机通用的应用)。

9. Game Activity C++
  • 用途:这是为游戏开发者准备的C++基础活动模板,适用于使用C++编写游戏的Android应用。

  • 特点:该模板包括C++代码支持,提供一个简易的框架来运行游戏逻辑。它可能集成了一些常见的游戏开发工具和库(如OpenGL、Cocos2d等),以便于快速启动游戏项目。

  • 适用场景:适用于使用C++进行Android游戏开发的开发者,尤其是那些有经验并希望在移动设备上开发高性能游戏的开发者。

10. Native C++

原生 C++ 会创建一个新项目,其中的空活动配置为使用 JNI。JNI 是 Java 原生接口。JNI 描述了 Android 从用 Java 或 Kotlin 编程语言编写的执行代码编译字节码与用 C/C++ 编写的原生代码交互的方式。JNI 与供应商无关,支持从动态共享库加载代码,虽然有时很麻烦,但效率很高。

  • 用途:这是一个基础的原生C++模板,专为需要直接使用C++编写Android应用的开发者设计。与Java/Kotlin不同,这种模板使用C++直接与底层硬件和操作系统交互。

  • 特点:开发者可以在此模板中使用C++与Java/Kotlin进行交互,或者完全使用C++实现应用逻辑。通常与JNI(Java Native Interface)或NDK(Native Development Kit)一起使用。

  • 适用场景:适用于需要处理大量计算或性能要求较高的应用(如游戏、图像处理应用等),开发者熟悉C++并希望直接在Android平台上运行原生代码。

开始我们的第一个项目

可以看看下面,这是我们的工程项目,一般而言,这个是默认的视图。不太方便而且眼花缭乱,所以我们需要更改一下视图:

在这里,选择跟我一样的Android

就会得到一个非常干净的:

展开了来看就是这样的

梳理一下:

manifests 文件夹
kotlin+java文件夹
res(资源)文件夹Drawable 文件夹Mipmap 文件夹Values 文件夹XML文件夹
Gradle 脚本

manifests文件夹

清单文件夹包含用于创建 android 应用程序的 AndroidManifest.xml。此文件包含有关我们应用程序的信息,例如 Android 版本、元数据、Kotlin 文件的状态包和其他应用程序组件。它充当 android 操作系统和我们的应用程序之间的中介。

<?xml version="1.0" encoding="utf-8"?>  <!-- XML 声明,表明使用 UTF-8 编码 -->
​
<manifest xmlns:android="http://schemas.android.com/apk/res/android"  <!-- Android 命名空间 -->xmlns:tools="http://schemas.android.com/tools">  <!-- 工具命名空间,用于辅助工具相关配置 -->
​<!-- 应用程序的基本配置 --><applicationandroid:allowBackup="true"  <!-- 是否允许备份应用数据,true 表示允许 -->android:dataExtractionRules="@xml/data_extraction_rules"  <!-- 数据提取规则,指定 XML 文件用于数据恢复和备份 -->android:fullBackupContent="@xml/backup_rules"  <!-- 完整备份内容的规则,指定应用数据的备份规则 -->android:icon="@mipmap/ic_launcher"  <!-- 应用图标,引用 mipmap 文件夹中的 ic_launcher 图标 -->android:label="@string/app_name"  <!-- 应用名称,引用 strings.xml 中的 app_name 字符串资源 -->android:roundIcon="@mipmap/ic_launcher_round"  <!-- 圆形图标,通常在支持圆形图标的设备上使用 -->android:supportsRtl="true"  <!-- 表示应用支持从右向左的布局,适用于阿拉伯语等语言 -->android:theme="@style/Theme.DemoOfMyFirstApplication"  <!-- 应用主题,引用 styles.xml 中的 Theme.DemoOfMyFirstApplication 样式 -->tools:targetApi="31">  <!-- 工具标记的目标 API 级别为 31(Android 12) --><!-- 定义应用程序的活动(Activity) --><activityandroid:name=".MainActivity"  <!-- 活动的类名,指定主活动为 MainActivity -->android:exported="true"  <!-- 活动是否可以由外部组件启动,true 表示可以外部访问 -->android:label="@string/app_name"  <!-- 活动的标签,通常是活动的标题,引用 strings.xml 中的 app_name 字符串资源 -->android:theme="@style/Theme.DemoOfMyFirstApplication">  <!-- 活动使用的主题,指定与应用相同的主题 --><!-- 活动的意图过滤器,用于定义该活动响应的 Intent 类型 --><intent-filter><action android:name="android.intent.action.MAIN" />  <!-- MAIN 动作,表示此活动是应用的主活动 --><category android:name="android.intent.category.LAUNCHER" />  <!-- LAUNCHER 类别,表示该活动是应用的启动活动 --></intent-filter></activity>
​</application>
​
</manifest>
​

java文件夹

java文件夹包含我们在应用开发过程中创建的所有 java 和 Kotlin 源代码 (.java) 文件,包括其他测试文件。如果我们使用 Kotlin 创建任何新项目,默认情况下,类文件 MainActivity.kt 文件将在软件包名称“com.example.demoofmyfirstapplication”下自动创建,如下所示。

package com.example.demoofmyfirstapplication  // 包名,定义了当前文件所在的包
​
// 导入必要的库和组件
import android.os.Bundle  // Bundle 类,用于传递和保存活动的状态
import androidx.activity.ComponentActivity  // 导入 ComponentActivity 类,它是 Activity 类的子类,支持 Jetpack Compose
import androidx.activity.compose.setContent  // 用于设置 Compose UI 内容
import androidx.activity.enableEdgeToEdge  // 用于启用 "Edge-to-Edge"(边缘到边缘)布局,适用于沉浸式屏幕
import androidx.compose.foundation.layout.fillMaxSize  // 用于设置视图填充最大可用空间
import androidx.compose.foundation.layout.padding  // 用于设置视图的内边距
import androidx.compose.material3.Scaffold  // Scaffold 组件,用于实现常见的 Material Design 布局结构
import androidx.compose.material3.Text  // 用于显示文本组件
import androidx.compose.runtime.Composable  // 用于定义 Compose 可组合函数
import androidx.compose.ui.Modifier  // Modifier 用于修饰 Compose 组件的外观和行为
import androidx.compose.ui.tooling.preview.Preview  // 用于预览 Compose 布局
import com.example.demoofmyfirstapplication.ui.theme.DemoOfMyFirstApplicationTheme  // 导入自定义的主题
​
// MainActivity 类,继承自 ComponentActivity,是应用的主活动
class MainActivity : ComponentActivity() {// onCreate 方法是 Activity 生命周期的一个重要方法,首次创建活动时调用override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)// 启用 "Edge-to-Edge" 布局,消除系统 UI(如状态栏)的干扰,允许视图内容扩展到屏幕的边缘enableEdgeToEdge()// 使用 setContent 方法设置 Compose UI 内容setContent {// 使用应用的主题,确保 UI 按照预设的样式进行渲染DemoOfMyFirstApplicationTheme {// Scaffold 是一个常见的 Material Design 布局结构,通常包含顶部栏、底部栏等Scaffold(modifier = Modifier.fillMaxSize()) { innerPadding ->// 调用 Greeting 函数,在界面上显示问候语// innerPadding 是 Scaffold 自动计算出的内边距,用来避免 UI 元素与屏幕边缘重叠Greeting(name = "Android",  // 传入一个字符串参数给 Greetingmodifier = Modifier.padding(innerPadding)  // 给 Greeting 添加内边距修饰符)}}}}
}
​
// 定义一个 Composable 函数,接收一个 name 参数并显示一个问候语
@Composable
fun Greeting(name: String, modifier: Modifier = Modifier) {// 使用 Text 组件显示文本,text 参数是显示的内容,modifier 用来修饰组件的外观Text(text = "Hello $name!",  // 显示的问候文本modifier = modifier  // 应用外部传入的修饰符)
}
​
// 用于预览 Composable 函数的布局和外观
@Preview(showBackground = true)  // 设置预览时显示背景
@Composable
fun GreetingPreview() {// 使用应用主题包装预览组件DemoOfMyFirstApplicationTheme {// 调用 Greeting 函数进行预览,传入 "Android" 作为参数Greeting("Android")}
}

资源 (res) 文件夹 资源文件夹是最重要的文件夹,因为它包含我们 Android 应用程序的所有非代码源,如图像、XML 布局和 UI 字符串。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/65567.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Compose multiplatform教程06】用IDEA编译Compose Multiplatform常见问题

当我们从Kotlin Multiplatform Wizard | JetBrains 下载ComposeMultiplatform项目时 会遇到无法正常编译/运行的情况&#xff0c;一般网页和桌面是可以正常编译的&#xff0c; 我这里着重解决如下问题 1:Gradle版本不兼容或者Gradle连接超时 2:JDK版本不兼容 3:Gradle依赖库连…

Python + 深度学习从 0 到 1(02 / 99)

希望对你有帮助呀&#xff01;&#xff01;&#x1f49c;&#x1f49c; 如有更好理解的思路&#xff0c;欢迎大家留言补充 ~ 一起加油叭 &#x1f4a6; 欢迎关注、订阅专栏 【深度学习从 0 到 1】谢谢你的支持&#xff01; ⭐ Keras 快速入门&#xff1a; 神经网络的基本数据结…

MySQL 数据库基础

目录 什么是数据库 数据库分类 关系型数据库 非关系型数据库 SQL子语言 MySQL MySQL 存储数据的组织方式 数据库操作 显示当前数据库 创建数据库 使用数据库 删除数据库 什么是数据库 数据库 是一个用于存储、管理和检索数据的系统&#xff0c;可以组织和保存大量…

《Vue3 二》Vue 的模板语法

在 React 中&#xff0c;想要编写 HTML&#xff0c;是使用 JSX&#xff0c;之后通过 Babel 将 JSX 编译成 React.createElement 函数调用&#xff1b;在 Vue 中&#xff0c;也支持 JSX 的开发模式&#xff0c;但大多数情况下都是使用基于 HTML 的模板语法&#xff0c;在模板中允…

高级技巧-使用Mysql 实现根据条件过滤整个分组数据

博客-mysql exists实现过滤所属条件对应分组的全部数据 在数据查询中&#xff0c;有时需要根据某一条件来过滤整个分组的数据&#xff0c;尤其是当某条记录满足特定条件时&#xff0c;需要将该组内的所有记录排除。本文将介绍如何使用 MySQL 的 EXISTS 关键字来实现这种分组过滤…

游戏引擎学习第67天

reviewing “apron”概念以更新区域 我们正在进行模拟区域的扩展工作&#xff0c;目标是通过增加一个更大的区域来支持更丰富的互动&#xff0c;尤其是那些可能超出摄像机视野的内容。现有的模拟区域包括摄像机能看到的区域和其周围的环境区域&#xff0c;但为了保证更高效的游…

计算机网络|数据流向剖析与分层模型详解

文章目录 一、网络中的数据流向二、计算机网络通信模型1.OSI 模型2.TCP/IP 模型3.TCP/IP五层模型3.1 分层架构描述3.2各层地址结构3.3UDP数据包报头结构 三、总结 一、网络中的数据流向 在计算机网络中&#xff0c;数据的流向是指数据从发送端到接收端的传输路径。数据流向涉及…

如何在 Spring Boot 微服务中设置和管理多个数据库

在现代微服务架构中&#xff0c;通常需要与多个数据库交互的服务。这可能是由于各种原因&#xff0c;例如遗留系统集成、不同类型的数据存储需求&#xff0c;或者仅仅是为了优化性能。Spring Boot 具有灵活的配置和强大的数据访问库&#xff0c;可以轻松配置多个数据库。在本综…

【Raven1靶场渗透】

文章目录 一、基础信息 二、信息收集 三、暴力破解 四、提权 一、基础信息 Kali IP &#xff1a;192.168.20.146 靶机IP &#xff1a;192.168.20.153 二、信息收集 nmap -sS -sV -p- -A 192.168.20.153 开放了22&#xff0c;80&#xff0c;111&#xff0c;58305端口 访…

视频监控平台:Liveweb视频汇聚融合平台智慧安防视频监控应用方案

Liveweb是一款功能强大、灵活部署的安防视频监控平台&#xff0c;支持多种主流标准协议&#xff0c;包括GB28181、RTSP/Onvif、RTMP等&#xff0c;同时兼容海康Ehome、海大宇等厂家的私有协议和SDK接入。该平台不仅提供传统安防监控功能&#xff0c;还支持接入AI智能分析&#…

Pytorch | 利用SMI-FGRM针对CIFAR10上的ResNet分类器进行对抗攻击

Pytorch | 利用I-FGSSM针对CIFAR10上的ResNet分类器进行对抗攻击 CIFAR数据集SMI-FGRM介绍SMI-FGRM算法流程 SMI-FGRM代码实现SMI-FGRM算法实现攻击效果 代码汇总smifgrm.pytrain.pyadvtest.py 之前已经针对CIFAR10训练了多种分类器&#xff1a; Pytorch | 从零构建AlexNet对CI…

基于PREEvision的UML设计

众所周知&#xff0c;PREEvision是一款强大的电子电气架构协同开发及管理软件&#xff0c;可以很好地帮助架构工程师完成架构开发工作&#xff0c;其功能包括需求管理、定义功能逻辑、系统软件开发、网络设计、线束设计及整体工程的产品线管理和变形管理等。随着工程师们越来越…

闲谭Scala(2)--安装与环境配置

1. 概述 Java开发环境安装&#xff0c;需要两步&#xff0c;第一安装JDK&#xff0c;第二配置环境变量。 Scala的话&#xff0c;也是两步&#xff0c;第一安装Scale环境&#xff0c;第二配置环境变量。 需要注意的是&#xff0c;配置环境变量&#xff0c;主要是想让windows操…

智慧地下采矿:可视化引领未来矿业管理

图扑智慧地下采矿可视化平台通过整合多源数据&#xff0c;提供实时 3D 矿井地图及分析&#xff0c;提升了矿产开采的安全性与效率&#xff0c;为矿业管理提供数据驱动的智能决策支持&#xff0c;推动行业数字化转型。

王鹤棣新剧《大奉打更人》开播 数据亮眼刷新招商纪录

临近年末&#xff0c;各类国产剧集仍频上新&#xff0c;档期竞争格外激烈。而由王鹤棣领衔主演的古装悬疑轻喜剧《大奉打更人》已于12月28日在CCTV-8和腾讯视频同步播出&#xff0c;开播即横扫各大榜单。该剧从定档官宣到开播&#xff0c;热度一路攀升&#xff0c;开播后更是掀…

数据中台从centos升级为国产操作系统后,资源增加字段时,提交报500错误

文章目录 背景一、步骤1.分析阶段2.查看nginx3.修改用户&#xff08;也可以修改所有者权限&#xff09; 背景 故障报错&#xff1a; nginx报错信息&#xff1a; 2024/12/19 15:25:31 [crit, 500299#0: *249 onen0 " /var/lib/nginx/tmp/cient body/0000000001" f…

BLE core 内容整理解释

本文内容比较杂散&#xff0c;只是做记录使用&#xff0c;后续会整理的有条理些 link layer 基本介绍 **Link Layer Control&#xff08;链路层控制&#xff09;**是蓝牙低功耗&#xff08;BLE&#xff09;协议栈的核心部分&#xff0c;负责实现设备间可靠、安全、低功耗的数…

【疑难杂症】 HarmonyOS NEXT中Axios库的响应拦截器无法拦截424状态码怎么办?

今天在开发一个HarmonyOS NEXT的应用的时候&#xff0c;发现http接口如果返回的状态码是424时&#xff0c;我在axios中定义的拦截器失效了。直接走到了业务调用的catch中。 问题表现&#xff1a; 我的拦截器代码如下&#xff1a; 解决办法&#xff1a; 先说解决办法&#xff…

聚类评价指标

聚类评价指标分为 内部指标 和 外部指标 两大类&#xff0c;用于评估聚类算法的性能。 一、内部评价指标 内部评价指标不依赖真实标签&#xff0c;主要通过聚类结果本身的紧凑性和分离性进行评估。 轮廓系数&#xff08;Silhouette Coefficient, SC&#xff09; 衡量数据点与其…

flask后端开发(1):第一个Flask项目

目录 一、Helloworddebug、host、port的配置 gitcode地址&#xff1a; https://gitcode.com/qq_43920838/flask_project.git 一、Helloword 一般是会创建两个文件夹和app.py app.py from flask import FlaskappFlask(__name__)app.route(/) def hello_world():return Hello…