- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
引用库的常规设置是Android Studio将库导入到主项目的根目录中。这并不是我们真正想要的,因为库的本质好处是要在许多项目之间共享它。如果我们更新导入的库中的代码,那么这将不会反映在先前导入到另一个项目中的库的代码中。
相反,我们的目标是创建一个Main Android项目,该项目可以引用存在于Android项目目录之外的自定义(您创建的)Android和Java库模块,并能够从Main内部编辑所有三个模块的代码。 Android项目。也就是说,我们最终要得到:
属于我们的Android主项目的根模块(“应用”);
一个Android库模块,该模块位于Android项目目录之外,但由我们的Main Android项目引用。
一个Java库模块,存在于Android项目目录之外,但由我们的Main Android项目引用。
...例如,所以我们有一个目录结构,例如...
..\LibraryRefDemo\MyMainProject
..\LibraryRefDemo\Libraries\MyAndroidLibrary
..\LibraryRefDemo\Libraries\MyJavaLibrary
最佳答案
目录
命名和目录约定
基本技巧
创建主要的Android项目
创建自定义Android库
从Android主项目引用自定义Android库
创建Java库/模块
主项目中的参考Java库
请编辑
命名和目录约定
首先,我们建立命名和目录约定(如果您不喜欢以下约定,请建立自己的约定)。
项目名称:PascalCase。
..\LibraryRefDemo\MyMainProject
..\LibraryRefDemo\Libraries\MyAndroidLibrary
..\LibraryRefDemo\Libraries\MyJavaLibrary
Application Name: MyMainProject
Project Location: ..\MyMainProject
// (package name for MyMainProject's root module: "app")
au.com.example.mymainproject
// (package name for MyAndroidLibrary's root module: "malmodule")
au.com.example.malmodule
// (package name for MyJavaLibrary' module where we placed our
// java code to be shared: "mjlmodule")
au.com.example.mjlmodule
app (MyMainProject's root module)
malmodule (MyAndroidLibrary's root module)
mjlmodule (The MyJavaLibrary's module where we placed our java code to be
shared. The MyJavaModule will also contain a root "app" module
for reasons of gradle integration)
settings.gradle (Project Settings)
中,我们使用以下内容引用库模块(而不是类似的库项目):
include ':app'
include ':malmodule'
// Despite the name "project" we actually need to reference the module directory
// of a project. It doesn't matter whether there is a trailing slash '/' or not.
project(':malmodule').projectDir =
new File(settingsDir, '../Libraries/MyAndroidLibrary/malmodule/')
include ':mjlmodule'
// Despite the name "project" we actually need to reference the module directory
// of a project. It doesn't matter whether there is a trailing slash '/' or not.
project(':mjlmodule').projectDir =
new File(settingsDir, '../Libraries/MyJavaLibrary/mjlmodule/')
build.gradle (Module: app)
,添加:
dependencies {
...
// Reference module rather than project.
implementation project(':malmodule')
implementation project(':mjlmodule')
...
}
MyMainProject
example.com.au
..\LibraryRefDemo\MyMainProject
au.com.example.mymainproject
<TextView
android:id="@+id/mymainproject_output"
android:layout_width="wrap_content"
<string name="mymainproject_cool_string">From My Main Project</string>
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
TextView textView = (TextView) findViewById(R.id.mymainproject_output);
String someString = getResources().getString(R.string.mymainproject_cool_string) + "\r\n";
textView.setText(someString);
}
}
From My Main Project
MyAndroidLibrary
example.com.au
..\LibraryRefDemo\Libraries\MyAndroidLibrary
au.com.example.malmodule
(我们使用此名称而不是默认名称来使我们稍后清楚地知道我们直接引用模块而不是项目)。
malmodule
<string name="myandroidlibrary_cool_string">From My Android Library</string>
<TextView
android:id="@+id/myandroidlibrary_output"
android:layout_width="wrap_content"
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
TextView myText = (TextView) findViewById(R.id.myandroidlibrary_output);
String someString = getResources().getString(R.string. myandroidlibrary_cool_string) + "\r\n";
myText.setText(someString);
}
}
From My Android Library
// Change ...
apply plugin: 'com.android.application'
// To ...
apply plugin: 'com.android.library'
...
android {
compileSdkVersion 26
defaultConfig {
// applicationId "au.com.example.malmodule"
...
settings.gradle (Project Settings)
文件。如下添加
:malmodule
引用。
include ':app'
include ':malmodule'
// Despite the name "project" we actually need to reference the module directory
// of a project. It doesn't matter whether there is a trailing slash '/' or not.
project(':malmodule').projectDir =
new File(settingsDir, '../Libraries/MyAndroidLibrary/malmodule/')
build.gradle (Module: app)
),然后添加...
dependencies {
...
// Reference module rather than project.
implementation project(':malmodule')
...
}
<string name="myandroidlibrary_cool_string">From My Android Library</string>
<TextView
android:id="@+id/mymainproject_output"
android:layout_width="wrap_content"
...
public class MainActivity extends Actvity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
TextView myText = (TextView) findViewById(R.id.mymainproject_output);
String someString = getResources().getString(R.string.mymainproject_cool_string) + "\r\n";
someString += getResources().getString(au.com.example.malmodule.R.string.myandroidlibrary_cool_string) + "\r\n";
myText.setText(someString);
}
}
<activity android:name=".MainActivity">
<!-- Don't make a main/launcher activity when being called by main app -->
<!--<intent-filter>-->
<!--<action android:name="android.intent.action.MAIN" />-->
<!--<category android:name="android.intent.category.LAUNCHER" />-->
<!--</intent-filter>-->
</activity>
From My Main Project
From My Anroid Library
<string name="myandroidlibrary_cool_string">My Android Library XXX</string>
MyJavaLibrary
example.com.au
\LibraryRefDemo\Libraries\MyJavaLibrary
au.com.example.myjavalibrary
(这将是根模块的名称空间,我们的Java代码将存在于我们随后将创建的另一个模块和名称空间中)。 [下一个]
mjlmodule
au.com.example.mjlmodule
Start
package au.com.example.mjlmodule;
public class Start {
public static void main(String[] args) {
System.out.println(getCoolString());
}
// Must be public because we want to reference the method directly later
public static String getCoolString() {
return "From My Java Library";
}
}
build.gradle (Module: mjlmodule)
:
apply plugin: 'java-library'
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
}
// You can delete or comment out ...
//sourceCompatibility = "1.7"
//targetCompatibility = "1.7"
MyJavaRun
au.com.example.mjlmodule.Start
\LibraryRefDemo\Libraries\MyJavaLibrary
mjlmodule
Default
From My Java Library
public class Start {
public static void main(String[] args) {
System.out.println(getCoolString());
}
// Must be public because we want to reference the method directly later
public static String getCoolString() {
return "From My Java Library YYY";
}
}
From My Java Library YYY
settings.gradle (Project Settings)
中添加mjlmodule信息:
include ':app'
include ':malmodule'
// Despite the name "project" we actually need to reference the module directory
// of a project. It doesn't matter whether there is a trailing slash '/' or not.
project(':malmodule').projectDir =
new File(settingsDir, '../Libraries/MyAndroidLibrary/malmodule/')
include ':mjlmodule'
// Despite the name "project" we actually need to reference the module directory
// of a project. It doesn't matter whether there is a trailing slash '/' or not.
project(':mjlmodule').projectDir =
new File(settingsDir, '../Libraries/MyJavaLibrary/mjlmodule/')
build.gradle (Module:app)
中,添加mjmodule信息:
dependencies {
implementation project(':malmodule')
implementation project(':mjlmodule')
...
}
package au.com.example.mjlmodule;
public class Start {
public static void main(String[] args) {
System.out.println(getCoolString());
}
// Must be public because we want to reference the method directly later
public static String getCoolString() {
return "From MyJavaLibrary YYY";
}
}
<TextView
android:id="@+id/mymainproject_output"
android:layout_width="wrap_content"
...
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
TextView textView = (TextView) findViewById(R.id.mymainproject_output);
String someString = getResources().getString(R.string.mymainproject_cool_string) + "\r\n";
someString += getResources().getString(au.com.example.malmodule.R.string.myandroidlibrary_cool_string) + "\r\n";
someString += au.com.example.mjlmodule.Start.getCoolString() + "\r\n";
myText.setText(someString);
}
}
From MyMainProject
From My Android Library XXX
From My Java Library YYY
public static String getCoolString() {
return "From My Java Library ZZZ";
}
From MyMainProject
From My Android Library XXX
From My Java Library ZZZ
关于android - 我们如何引用位于Android Main Project目录之外的自定义Android和Java库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49268039/
我正在使用 javascript 并有以下类: const Product = require('../models').Product class ProductService { cons
我正在开发一个简单的应用程序,宠物用户可以在其中创建关于他们宠物的板并在板上显示图片。 我正在尝试创建一个功能,用户可以点击他们的图板,将他们重定向到他们的图板,该图板将显示他们所有的宠物图片。 当我
我有这样的事情:循环遍历 ids,并对每个 ids 向服务器(同一域)发出 ajax 请求 (async:true) 并将接收到的数据附加到 DOM 元素。这不是一项艰巨的任务,它确实有效。示例代码:
我正在尝试使用 Pillow 在我的网络应用程序中添加用户可上传的图像。我创建了一个 Django Upload 模型并将其注册到 Admin 中。当我使用管理控制台添加照片后,我收到以下错误。最初该
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
说到 UINavigationBar 时我有点困惑。我以编程方式设置它,它的作用是将我的 viewController 向下推(因此在启动应用程序后看不到 Storyboard中看到的 View 底部
我有以下查询,它可以满足我的要求,并显示从出生日期转换而来的人们的年龄。但我现在想通过说大于或小于这些年龄来缩小结果范围,但我不知道该怎么做。 SELECT u.`id` as `user_id`
我有一个 ListView (不是 recyclerView),其中每一行都有一个按钮、几个 TextView 和一个 EditText。单击特定按钮(“editTremp”)后,我希望 EditTe
我的 cellAtIndexPath 中有一个查询。正如常见的那样,此查询从单元格行索引处的数组中获取对象。我想知道每次加载 tableView 时是否只有一个查询,还是将其算作每个 indexPat
我目前正在探索 http://www.ecovivo.be/rubriek/food 上使用的模板中的错误. 问题:访问该链接时,您会注意到右侧有一个带有内容的大型 float 图像。现在一切正常。但
我在 ViewController 之间通过引用传递特定模型的数组。 如果我更改数组中特定元素的任何值,它会在所有 ViewController 中很好地反射(reflect),但是当我从该数组中删除
svg 包含更多元素,其中之一是下拉选择器。我遇到的问题是选择器只能在其顶部边缘被点击,而不能在选择器的其他任何地方被点击。 选择器称为 yp-date-range-selector。在下一张图片中,
我的元素使用 20 行 20 列的 css 网格布局(每个单元格占屏幕的 5%)。其中一个页面有一个按钮。最初该页面包含在网格第 5-8 列和网格第 6-9 行中,按钮本身没有问题,但我需要将其居中放
我想使用 CSS Trick 使图像居中.但是如果图像大小是随机的(不固定的)怎么办。令人惊讶的是,我不想保持图像响应,我想在不改变其宽度或高度(实际像素)的情况下将图像置于中心。 下面是我的代码:
我正在尝试在网址之间进行路由。产品是一个类: from django.db import models from django.urls import reverse # Create your mo
我正在通过查看 Django 教程来制作网站。我收到一个错误: NoReverseMatch at /polls/ Reverse for 'index' with no arguments not
我一直在试用 Django 教程 Django Tutorial Page 3并遇到了这个错误 "TemplateDoesNotExist at /polls/ " . 我假设问题出在我的代码指向模板
我有一个应用程序,其中大部分图像资源都存储在单独的资源包中(这样做是有正当理由的)。这个资源包与主应用程序包一起添加到项目中,当我在 Interface Builder 中设计我的 NIB 时,所有这
我使用 Xcode 6.3.2 开发了一个 iPad 应用程序。我将我的应用程序提交到 App Store 进行审核,但由于崩溃而被拒绝。以下是来自 iTunes 的崩溃报告。 Incident Id
我正在使用以下内容来显示水平滚动条: CSS: div { width: 300px; overflow-x: scroll; } div::-webkit-scrollbar {
我是一名优秀的程序员,十分优秀!