Android开发学习(9)--BeatBox(2)

2024-03-04 00:30
文章标签 android 学习 开发 beatbox

本文主要是介绍Android开发学习(9)--BeatBox(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、实验步骤
    • 1.颜色资源
      • a 定义几种颜色(res/values/colors.xml)
      • b 添加样式(res/values/styles.xml)
      • c 使用样式(res/layout/list_item_sound.xml)
      • d 继承样式(res/layout/styles.xml)
    • 2. 添加主题颜色
      • a 自定义主题属性(res/values/styles.xml)
      • b 设置窗口背景(res/values/styles.xml)
      • c 使用BeatBoxButton样式(res/values/styles.xml)
  • 二、模拟器运行结果
  • 三、真机运行结果


前言

既然BeatBox应用的音效能吓退人,它的用户界面也应透出一定的威慑力。
当前,BeatBox应用依然还是一副Android千年不变的老面孔。按钮普通,配色灰暗。整个应 用看上去毫不起眼,没有品牌特色。
不过我们有技术,使用样式和主题,就能定制出漂亮的用户界面。与之前相比,新界面更加美观、惹眼,独具风格。

一、实验步骤

1.颜色资源

a 定义几种颜色(res/values/colors.xml)

<resources>      
<color name="colorPrimary">#3F51B5</color>     
<color name="colorPrimaryDark">#303F9F</color>     
<color name="colorAccent">#FF4081</color> <color name="red">#F44336</color>     <color name="dark_red">#C3352B</color>     <color name="gray">#607D8B</color>     <color name="soothing_blue">#0083BF</color>     <color name="dark_blue">#005A8A</color> </resources> 

b 添加样式(res/values/styles.xml)

<resources>  <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">   <item name="colorPrimary">@color/colorPrimary</item>   <item name="colorPrimaryDark">@color/colorPrimaryDark</item>   <item name="colorAccent">@color/colorAccent</item>     </style> <style name="BeatBoxButton">     <item name="android:background">@color/dark_blue</item>     </style> 
</resources>

c 使用样式(res/layout/list_item_sound.xml)

<Button   
style="@style/BeatBoxButton"   
android:layout_width="match_parent"   
android:layout_height="120dp"  
android:onClick="@{() -> viewModel.onButtonClicked()}"  
android:text="@{viewModel.title}"  
tools:text="Sound name"/> 

d 继承样式(res/layout/styles.xml)

<style name="BeatBoxButton">    <item name="android:background">@color/dark_blue</item> </style> 
<style name="BeatBoxButton.Strong">     
<item name="android:textStyle">bold</item> 
</style>

2. 添加主题颜色

a 自定义主题属性(res/values/styles.xml)

<style name="AppTheme" parent="Theme.AppCompat">     
<item name="colorPrimary">@color/red</item>     
<item name="colorPrimaryDark">@color/dark_red</item>     
<item name="colorAccent">@color/gray</item> 
</style> 

b 设置窗口背景(res/values/styles.xml)

<style name="AppTheme" parent="Theme.AppCompat">     
<item name="colorPrimary">@color/red</item>      
<item name="colorPrimaryDark">@color/dark_red</item>     
<item name="colorAccent">@color/gray</item> <item name="android:windowBackground">@color/soothing_blue</item> </style>

c 使用BeatBoxButton样式(res/values/styles.xml)

<resources> <style name="AppTheme" parent="Theme.AppCompat">    <item name="colorPrimary">@color/red</item>   <item name="colorPrimaryDark">@color/dark_red</item>   <item name="colorAccent">@color/gray</item> <item name="android:windowBackground">@color/soothing_blue</item>   <item name="buttonStyle">@style/BeatBoxButton</item>     </style> <style name="BeatBoxButton" parent="Widget.AppCompat.Button">   <item name="android:background">@color/dark_blue</item>     </style> 
</resources> 

二、模拟器运行结果

三、真机运行结果

这篇关于Android开发学习(9)--BeatBox(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/771424

相关文章

VSCode开发中有哪些好用的插件和快捷键

《VSCode开发中有哪些好用的插件和快捷键》作为全球最受欢迎的编程工具,VSCode的快捷键体系是提升开发效率的核心密码,:本文主要介绍VSCode开发中有哪些好用的插件和快捷键的相关资料,文中... 目录前言1、vscode插件1.1 Live-server1.2 Auto Rename Tag1.3

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

Android使用java实现网络连通性检查详解

《Android使用java实现网络连通性检查详解》这篇文章主要为大家详细介绍了Android使用java实现网络连通性检查的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录NetCheck.Java(可直接拷贝)使用示例(Activity/Fragment 内)权限要求

Python+wxPython开发一个文件属性比对工具

《Python+wxPython开发一个文件属性比对工具》在日常的文件管理工作中,我们经常会遇到同一个文件存在多个版本,或者需要验证备份文件与源文件是否一致,下面我们就来看看如何使用wxPython模... 目录引言项目背景与需求应用场景核心需求运行结果技术选型程序设计界面布局核心功能模块关键代码解析文件大

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

2025最新版Android Studio安装及组件配置教程(SDK、JDK、Gradle)

《2025最新版AndroidStudio安装及组件配置教程(SDK、JDK、Gradle)》:本文主要介绍2025最新版AndroidStudio安装及组件配置(SDK、JDK、Gradle... 目录原生 android 简介Android Studio必备组件一、Android Studio安装二、A

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求: