tags:

views:

3816

answers:

4

How do you setup a project that can result in a jar library file that can be used for android? I want to create a custom library across all projects.

Few other questions:

  1. Does it need to be compiled against a specific version of android sdk?
  2. When an android package is compiled against a jar library does the classes necessary to work with the code get compiled with main code into the apk or does the entire jar get included?
  3. Any notable optimizations or pitfalls I need to know about with using a jar instead of integrating the code directly?
  4. Does the jar have to be signed like the apk needs to?
+13  A: 

There is nothing special you need to do to your project setup to create a jar file that will work in an Android app. Just create a normal Java project in Eclipse.

  1. It doesn't need to be compiled against Android at all. You can include any jar file as long as it doesn't reference classes that aren't included in Android. Just include your jar file in your build path of your Android projects in Eclipse, and it will automatically be included in your APK file.

  2. Not sure but I assume all classes in the jar file get included in the APK.

  3. I don't think just including some classes in a jar vs. in the project directly will make any difference in the resulting APK.

mbaird
4. The JAR does not need to be signed.
Christopher
I just ran into a roadblock. I have custom layouts that add ids to the R.java file and I have other Android dependencies. How do I get these into a jar format?
Jeremy Edwards
You can only have Java class files in a jar. You can't put custom layout XML in there. You have to just copy those into your project.
mbaird
A: 

If you look in the android.jar file under platforms/android-X.X/android.jar file it does include layout XML items so you should be able to create one as well. I just am not sure on exactly how you do this and how you reference them in the other project.

ddcruver
+6  A: 

Google just release a new version of the SDK that handles Shared Libraries!

http://developer.android.com/guide/developing/eclipse-adt.html#libraryProject

ADT 0.9.7 (May 2010)

Library projects:
The ADT Plugin now supports the use of library projects during development, a capability that lets you store shared Android application code and resources in a separate development project. You can then reference the library project from other Android projects and, at build time, the tools compile the shared code and resources as part of the dependent applications. More information about this feature is available in the Developing in Eclipse with ADT document. If you are not developing in Eclipse, SDK Tools r6 provides the equivalent library project support through the Ant build system.

ddcruver
I just want to also mention, as of writing this MotoDev Studio if you use it does not support the ability to use Librarys. It overrides many of the standard ADT GUIs and it hides the one that allows you to make a Project a Library. I am sure it will be fixed in time.
ddcruver
MotoDev Studio 1.2.1 supports shared libraries now.
Timothy Lee Russell
Yeah they update it about two days after Google release the new ADT forgot to update this.
ddcruver
ADT 0.9.7 gets us 80% of what we want, but it still has these drawbacks: (1) a library project cannot hold .aidl files, (2) a library project cannot depend on another library project, (3) a library project cannot hold assets
Joseph Johnson
Yeah that is an unfortunate limitation. Possibly you will have to try to create pure java projects for some parts in which don't directly need to be compiled by the android compiler. Also in eclipse you could possibly use file links in eclipse to include code from other android libraries but I haven't tested this.
ddcruver
A: 

I asked myselft the same question: can I export and reuse a layout in Android. I tried the following: export a project with XML resources to a JAR file, and then try to access a layout through it's R.layout. Of course it didn't work, as R.layout.main was an integer, the same integer as was associated to the single layout (relative.xml) defined in the host project's R.layout.

The Android SDK kompiles layout xml files into View resources, and as XML files in the included JAR file are not layout xml files, they are not compiled and no ID is associated to them in R.layout.

If you want to export a layout from your project, then you should export it as XML, and import it to the new project as a layout resource, not as part of an external library.

If you want to reuse layouts from a JAR, you have to create a sublcalss of a View, and build the layout from code. Than you can instantiate it and set the created instance as the View of the Activity, or add the instance to the View of your Activity.

Balazs Lajtha