正确引入setupdesign和setupcompat的方式

2024-09-06 08:58

本文主要是介绍正确引入setupdesign和setupcompat的方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

正确引入setupdesign和setupcompat的方式

引入方式如下:

├── app
│   ├── app.iml
│   ├── assests
│   ├── build
│   ├── build.gradle   // 配置1
│   ├── libs
│   ├── proguard-rules.pro
│   └── src
├── build.gradle
├── TESTX.iml
├── gradle
│   └── wrapper
├── gradle.properties
├── gradlew
├── gradlew.bat
├── local.properties
├── settings.gradle    //  配置2
├── setupcompat
│   ├── Android.bp
│   ├── AndroidManifest.xml
│   ├── build
│   ├── build.gradle
│   ├── TESTX.setupcompat.iml
│   ├── exempting_lint_checks.txt
│   ├── LICENSE
│   ├── lint.xml
│   ├── main
│   ├── METADATA
│   ├── MODULE_LICENSE_APACHE2
│   ├── OWNERS
│   ├── partnerconfig
│   ├── proguard.flags
│   └── setupcompat.iml
├── setupdesign
│   ├── Android.bp
│   ├── build
│   ├── build.gradle
│   ├── TESTX.setupdesign.iml
│   ├── exempting_lint_checks.txt
│   ├── LICENSE
│   ├── lint.xml
│   ├── main
│   ├── METADATA
│   ├── MODULE_LICENSE_APACHE2
│   ├── NOTICE
│   ├── OWNERS
│   ├── proguard.flags
│   ├── setupdesign.iml
│   └── strings

验证环境Android R.

setupdesign和setupcompat来自aosp /external/setupcompat和/external/setupdesign,可以通过gradle引入自有工程。

配置1:

// app/build.gradle
dependencies {implementation fileTree(dir: 'libs', include: ['*.jar'])// 关键implementation project(path: ':setupcompat')implementation project(path: ':setupdesign')implementation "com.google.android.material:material:1.2.0"
}

配置2:

// settings.gracle
rootProject.name='TESTX'
include ':app'
include(':setupdesign')
project(':setupdesign').projectDir = new File(settingsDir, './setupdesign')
include(':setupcompat')
project(':setupcompat').projectDir = new File(settingsDir, './setupcompat')

主工程里边直接引用相关布局即可。

根据setupcompat 导入提示:

//TESTX/setupcompat/build.gradle
/*** Include this gradle file if you are building against this as a standalone gradle library project,* as opposed to building it as part of the git-tree. This is typically the file you want to include* if you create a new project in Android Studio.** For example, you can include the following in your settings.gradle file:*      include ':setupcompat'*      project(':setupcompat').projectDir = new File(PATH_TO_THIS_DIRECTORY)** And then you can include the :setupcompat project as one of your dependencies*      dependencies {*          implementation project(path: ':setupcompat')*      }*/apply plugin: 'com.android.library'android {// Not specifying compileSdkVersion here so clients can specify it; must be at least QcompileSdkVersion 30defaultConfig {minSdkVersion 14targetSdkVersion 30}buildTypes {release {minifyEnabled falseproguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard.flags'}}sourceSets.main {manifest.srcFile 'AndroidManifest.xml'java.srcDirs = ['main/java', 'partnerconfig/java']aidl.srcDirs = ['main/aidl']res.srcDirs = ['main/res']}compileOptions {sourceCompatibility JavaVersion.VERSION_1_8targetCompatibility JavaVersion.VERSION_1_8}
}dependencies {implementation "androidx.annotation:annotation:1.0.0"
}

针对这个提示:

    // Not specifying compileSdkVersion here so clients can specify it; must be at least Q
    compileSdkVersion 30

本地测试好像不给不行,必须给; 不给sync project直接报错。

A problem occurred configuring project ':setupcompat'.
> compileSdkVersion is not specified.

 

这篇关于正确引入setupdesign和setupcompat的方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念

【即时通讯】轮询方式实现

技术栈 LayUI、jQuery实现前端效果。django4.2、django-ninja实现后端接口。 代码仓 - 后端 代码仓 - 前端 实现功能 首次访问页面并发送消息时需要设置昵称发送内容为空时要提示用户不能发送空消息前端定时获取消息,然后展示在页面上。 效果展示 首次发送需要设置昵称 发送消息与消息展示 提示用户不能发送空消息 后端接口 发送消息 DB = []@ro

脏页的标记方式详解

脏页的标记方式 一、引言 在数据库系统中,脏页是指那些被修改过但还未写入磁盘的数据页。为了有效地管理这些脏页并确保数据的一致性,数据库需要对脏页进行标记。了解脏页的标记方式对于理解数据库的内部工作机制和优化性能至关重要。 二、脏页产生的过程 当数据库中的数据被修改时,这些修改首先会在内存中的缓冲池(Buffer Pool)中进行。例如,执行一条 UPDATE 语句修改了某一行数据,对应的缓

Java 多线程的基本方式

Java 多线程的基本方式 基础实现两种方式: 通过实现Callable 接口方式(可得到返回值):

前端form表单+ifarme方式实现大文件下载

// main.jsimport Vue from 'vue';import App from './App.vue';import { downloadTokenFile } from '@/path/to/your/function'; // 替换为您的函数路径// 将 downloadTokenFile 添加到 Vue 原型上Vue.prototype.$downloadTokenF

SigLIP——采用sigmoid损失的图文预训练方式

SigLIP——采用sigmoid损失的图文预训练方式 FesianXu 20240825 at Wechat Search Team 前言 CLIP中的infoNCE损失是一种对比性损失,在SigLIP这个工作中,作者提出采用非对比性的sigmoid损失,能够更高效地进行图文预训练,本文进行介绍。如有谬误请见谅并联系指出,本文遵守CC 4.0 BY-SA版权协议,转载请联系作者并注

SAM2POINT:以zero-shot且快速的方式将任何 3D 视频分割为视频

摘要 我们介绍 SAM2POINT,这是一种采用 Segment Anything Model 2 (SAM 2) 进行零样本和快速 3D 分割的初步探索。 SAM2POINT 将任何 3D 数据解释为一系列多向视频,并利用 SAM 2 进行 3D 空间分割,无需进一步训练或 2D-3D 投影。 我们的框架支持各种提示类型,包括 3D 点、框和掩模,并且可以泛化到不同的场景,例如 3D 对象、室