292

I'm trying to develop/port a game to Android, but it's in C, and Android supports Java, but I'm sure there must be a way to get a C app on there, anyone knows of a way to accomplish this?

Doc Brown
  • 19,739
  • 7
  • 52
  • 88
Robert Gould
  • 68,773
  • 61
  • 187
  • 272
  • only if you jailbreak the phone AFAIK. – Cogsy Jun 16 '09 at 15:16
  • 66
    Isn't jailbraking for iPhones? – Robert Gould Jun 16 '09 at 15:19
  • 1
    The G1 doesn't allow root access by default, and there are a lot of restrictions in place regarding what can be executed outside of the 'Android' environment. I wouldn't have much hope finding a way to execute native code from within Android. – Cogsy Jun 16 '09 at 15:23
  • 2
    but I've downloaded DOOM for Android from the marketplace. So it should be doable – Robert Gould Jun 16 '09 at 15:33
  • Make your Application a shell the holds a compilre and source. On first launch compile your application on the Android Phone and then execute. – Martin York Jun 16 '09 at 17:46
  • 4
    DOOM for Android is written in Java http://code.google.com/p/doom-for-android/source/browse/#svn/trunk – Marco Mustapic Jun 26 '09 at 01:07
  • @Marco M. Wow, is all I can say. Can't believe somone would ave rewritten it, but it seems your right!!! – Robert Gould Jun 26 '09 at 07:27
  • @Robert Gould, many people have re-written DOOM, I personally know of 2 people who have done so. Its open source, so its a good project for people starting off in games programming as they can see how it was originally done as a reference (plus, it gives them something to aim for and something rather flashy to show off at the end). – Grant Peters Jul 30 '10 at 06:47
  • you can also use [C++ builder](http://www.embarcadero.com/landing-pages/try-cbuilder-usca?cid=701G0000000w6kB&gclid=Cj0KEQjwk7msBRCJj67khY2z_NIBEiQAPTFjv7z5NGkTsUEycHYYHqEh2LsiP016cwpieUFRus1jLtUaAiQn8P8HAQ) – A-Sharabiani Jun 27 '15 at 21:48

20 Answers20

250

For anyone coming to this via Google, note that starting from SDK 1.6 Android now has an official native SDK.

You can download the Android NDK (Native Development Kit) from here: https://developer.android.com/ndk/downloads/index.html

Also there is an blog post about the NDK:
http://android-developers.blogspot.com/2009/06/introducing-android-15-ndk-release-1.html

Jonathan Leffler
  • 730,956
  • 141
  • 904
  • 1,278
Andy Johnson
  • 7,938
  • 4
  • 33
  • 50
41

The Android NDK is a toolset that lets you implement parts of your app in native code, using languages such as C and C++. For certain types of apps, this can help you reuse code libraries written in those languages.

For more info on how to get started with native development, follow this link.

Sample applications can be found here.

MannyNS
  • 4,703
  • 2
  • 22
  • 16
20

Normally, you have to:

  1. Install Google Android NDK. It contains libs, headers, makfile examples and gcc toolchain
  2. Build an executable from your C code for ARM, optimize and link it with provided libs if required
  3. Connect to a phone using provided adb interface and test your executable

If you are looking to sell an app:

  1. Build a library from your C code
  2. Create simple Java code which will use this library
  3. Embed this library into application package file
  4. Test your app
  5. Sell it or distribute it for free
psihodelia
  • 29,566
  • 35
  • 108
  • 157
14

Google has released a Native Development Kit (NDK) (according to http://www.youtube.com/watch?v=Z5whfaLH1-E at 00:07:30).

Hopefully the information will be updated on the google groups page (http://groups.google.com/group/android-ndk), as it says it hasn't been released yet.

I'm not sure where to get a simple download for it, but I've heard that you can get a copy of the NDK from Google's Git repository under the donut branch.

Marc
  • 2,593
  • 2
  • 18
  • 21
12

The official position seems to be that this isn't something you'd ever "want to do". See this thread on the Android Developers list. Google envisage android running on a variety of different devices (CPUs, displays, etc). The best way to enable development is therefore to use (portable) managed code that targets the Dalvik VM. For this reason, the Android SDK doesn't support C/C++.

BUT, take a look at this page:

Android includes a set of C/C++ libraries used by various components of the Android system. These capabilities are exposed to developers through the Android application framework.

The managed application framework appears to be layered on-top of these libraries. The page goes on to list the C/C++ libs: standard C library, media, 3D, SQL lite, and others.

So all you need is a compiler chain that will compile C/C++ to the appropriate CPU (ARM, in the case of the G1). Some brief instructions on how to do this are here.

What I don't know is where to find descriptions of the APIs that these libraries provide. I'd guess there may be header files buried in the SDK somewhere, but documentation may be sketchy/missing. But I think it can be done!

Hope thats useful. For the record, I haven't written any native android apps - just a few simple managed ones.

Andy

Andy Johnson
  • 7,938
  • 4
  • 33
  • 50
8

You can use nestedvm to translate C (or other GCC languages) into Java bytecode, and use that as the basis of your port. For example, see the Android port of Simon Tathams portable puzzle collection.

I expect this method is made obsolete by the NDK, but it might not be in if some networks or something don't allow people to upgrade their phones.

rjmunro
  • 27,203
  • 20
  • 110
  • 132
8

Google has already launched Google I/O 2011: Bringing C and C++ Games to Android session which is available at http://www.youtube.com/watch?v=5yorhsSPFG4

which is good to understand the use of NDK for writing application in c and c++ for android.

If you just want to cross compile any console based native game and run them on android then this Article has shown 3 methods for the same.

1: Static compilation using standalone toolchain

2: Cross compilation using Android NDK’s toolchain

3: Cross compilation using AOSP source code

Jeegar Patel
  • 26,264
  • 51
  • 149
  • 222
7

Looking at this it seems it is possible:

"the fact is only Java language is supported doesn’t mean that you cannot develop applications in other languages. This have been proved by many developers, hackers and experts in application development for mobile. The guys at Elements Interactive B.V., the company behind Edgelib library, succeeded to run native C++ applications on the Android platform, even that at this time there is still many issues on display and sound … etc. This include the S-Tris2 game and a 3D animation demo of Edgelib."

Jonathan Leffler
  • 730,956
  • 141
  • 904
  • 1,278
backslash17
  • 5,300
  • 4
  • 31
  • 46
7

Maybe you are looking for this?

http://www.mosync.com/

It is a middle layer for developing for several mobile platforms using c++.

joepal
  • 319
  • 1
  • 3
  • 4
  • 2
    link is 404 not found. It is always a good idea to put in some content from the original post into the answer in case the site owner wins the lottery, divorces his wife and moves to Bahamas. – Zuzlx Sep 08 '15 at 23:19
6

Since 2009 there is a development on this matter.
Necessitas - Qt(C++ framework) for Android
Getting started video.

zkunov
  • 3,362
  • 1
  • 20
  • 17
5

Take a look at google ndk group it looks promising, first version of the NDK will be available in 1H2009.

Update: And it is released http://android-developers.blogspot.com/2009/06/introducing-android-15-ndk-release-1.html

Gordon Freeman
  • 1,117
  • 9
  • 22
5

I'm not sure the NDK provides full coverage of the official Java API.

From http://developer.android.com/sdk/ndk/index.html#overview :

Please note that the NDK does not enable you to develop native-only applications. Android's primary runtime remains the Dalvik virtual machine.

Android Eve
  • 14,864
  • 26
  • 71
  • 96
3

Google just released the NDK which allows exactly that.

http://feedproxy.google.com/~r/blogspot/hsDu/~3/2foWz7hwFtE/introducing-android-15-ndk-release-1.html

It can be found here: http://developer.android.com/sdk/ndk/1.5_r1/index.html

Alexander Stolz
  • 7,454
  • 12
  • 57
  • 64
2

This blog post may be a good start: http://benno.id.au/blog/2007/11/13/android-native-apps Unfortunately, lots of the important stuff is "left as an exercise to the reader".

Krzysiek Goj
  • 1,598
  • 4
  • 16
  • 18
2

Native C/c++ Files libstdc++.* from your Ubuntu are x86 (or x86_64) binaries but Android devices and emulators are ARM. Of course, this will not work anyway, even if you'll set correct soname. This is very naive way which leads nowhere. Android has very limited support of C++ meaning there is no exceptions, standard C++ library (including STL) and RTTI. If you need such functionality, use my custom NDK distribution from

http://crystax.net/android/ndk.php - it support full C++ features listed above.

Why is there error: undefined reference to '__cxa_end_cleanup' link error. Android stlport

time. Because there is no link to libstdc + +. A. So wrong.

Because it uses some static library, it is necessary to link the full libstdc + +. A. Can

http://crystax.net/android/ndk.php here to download the package

sources \ cxx-stl \ gnu-libstdc + + \ libs \ armeabi directory.

Android on its own libstdc + + support is limited, it must be linked to a complete libstdc + +. A the job.

Add file in Android.mk LOCAL_LDFLAGS = $ (LOCAL_PATH) / libs / libcurl.a \

 $ (LOCAL_PATH) / libs / liblua.a \
 `$ (LOCAL_PATH) / libs / libstdc + +. A`  

And LOCAL_CPPFLAGS + =-lstdc + +-fexceptions can be compiled

Community
  • 1
  • 1
2

I do not know a tutorial but a good development tool: Airplay SDK from Ideaworks Labs. (Recently rebranded "Marmelade") Using C/C++ you can build apps for Windows Mobile, iPhones, Android. The only component I didn't like was the GUI composer - a buggy one, but you always can substitute it with the Notepad.

AShelly
  • 34,686
  • 15
  • 91
  • 152
zergius
  • 344
  • 1
  • 6
  • 12
2

You can download c4droid and then install the GCC plugin and install to your SD. From the shell I just traverse to the directory where the GCC binary is and then call it to make an on board executable.

find / -name gcc

/mnt/sdcard/Android/data/com.n0n3m4.droidc/files/gcc/bin/arm-linux-androideabi-gcc

cat > test.c

#include<stdio.h>
int main(){ 
 printf("hello arm!\n");
return 0;
}

./arm-linux-androideabi-gcc test.c -o test

./test

hello arm!

elahtrebor
  • 104
  • 1
  • 1
1

There is a plan to allow C/C++ libraries in the next SDK version of Android (Codename Eclair?)To date, it's not possible through the Android Java SDK. However, you can grab the HUGE open source project, roll your own libraries, and then flash your own device...but anyone who wants to use your library will have to flash your custom build as well.

haseman
  • 11,213
  • 8
  • 41
  • 38
-7

Short answer: You can't.

@Backslash17: Looking through the article and the following link with installation instructions, all the company got working is to launch a self compiled executable on the emulator, bypassing the android framework. Once you have the emulator you can telnet in and have a linux shell. Running a linux program there is trivial of course. But that's not working for phones without jailbreak(aka root access) and not deliverable on the market.

Unless Google opens other opportunities or someone writes a custom compiler that compiles Language X into Dalvik bytecode (Dalvik is the VM that runs Android programs) you won't be able to write native code.

buster
  • 1,071
  • 1
  • 10
  • 15