Add extend example for Android
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@13831 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
593c708a78
commit
72fc742f88
15 changed files with 430 additions and 0 deletions
15
Examples/android/extend/AndroidManifest.xml
Normal file
15
Examples/android/extend/AndroidManifest.xml
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
package="org.swig.extendexample"
|
||||||
|
android:versionCode="1"
|
||||||
|
android:versionName="1.0">
|
||||||
|
<application android:label="@string/app_name" >
|
||||||
|
<activity android:name="SwigExtend"
|
||||||
|
android:label="@string/app_name">
|
||||||
|
<intent-filter>
|
||||||
|
<action android:name="android.intent.action.MAIN" />
|
||||||
|
<category android:name="android.intent.category.LAUNCHER" />
|
||||||
|
</intent-filter>
|
||||||
|
</activity>
|
||||||
|
</application>
|
||||||
|
</manifest>
|
||||||
29
Examples/android/extend/Makefile
Normal file
29
Examples/android/extend/Makefile
Normal file
|
|
@ -0,0 +1,29 @@
|
||||||
|
TOP = ../..
|
||||||
|
SWIG = $(TOP)/../preinst-swig
|
||||||
|
TARGET = example
|
||||||
|
INTERFACE = example.i
|
||||||
|
PACKAGEDIR = src/org/swig
|
||||||
|
PACKAGENAME= org.swig.extendexample
|
||||||
|
SWIGOPT = -package $(PACKAGENAME) -outdir $(PACKAGEDIR)/extendexample
|
||||||
|
PROJECTNAME= SwigExtend
|
||||||
|
TARGETID = 1
|
||||||
|
|
||||||
|
all:: android
|
||||||
|
|
||||||
|
android::
|
||||||
|
android update project --target $(TARGETID) --name $(PROJECTNAME) --path .
|
||||||
|
$(SWIG) -c++ -java $(SWIGOPT) -o jni/$(TARGET)_wrap.cpp jni/$(INTERFACE)
|
||||||
|
ndk-build
|
||||||
|
ant debug
|
||||||
|
|
||||||
|
install::
|
||||||
|
-adb uninstall $(PACKAGENAME)
|
||||||
|
adb install bin/$(PROJECTNAME)-debug.apk
|
||||||
|
|
||||||
|
clean::
|
||||||
|
ant clean
|
||||||
|
rm -f jni/$(TARGET)_wrap.cpp
|
||||||
|
rm -f `find $(PACKAGEDIR) -name \*.java | grep -v $(PROJECTNAME).java`
|
||||||
|
|
||||||
|
|
||||||
|
check: all
|
||||||
17
Examples/android/extend/ant.properties
Normal file
17
Examples/android/extend/ant.properties
Normal file
|
|
@ -0,0 +1,17 @@
|
||||||
|
# This file is used to override default values used by the Ant build system.
|
||||||
|
#
|
||||||
|
# This file must be checked in Version Control Systems, as it is
|
||||||
|
# integral to the build system of your project.
|
||||||
|
|
||||||
|
# This file is only used by the Ant script.
|
||||||
|
|
||||||
|
# You can use this to override default values such as
|
||||||
|
# 'source.dir' for the location of your java source folder and
|
||||||
|
# 'out.dir' for the location of your output folder.
|
||||||
|
|
||||||
|
# You can also use it define how the release builds are signed by declaring
|
||||||
|
# the following properties:
|
||||||
|
# 'key.store' for the location of your keystore and
|
||||||
|
# 'key.alias' for the name of the key to use.
|
||||||
|
# The password will be asked during the build when you use the 'release' target.
|
||||||
|
|
||||||
85
Examples/android/extend/build.xml
Normal file
85
Examples/android/extend/build.xml
Normal file
|
|
@ -0,0 +1,85 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project name="SwigExtend" default="help">
|
||||||
|
|
||||||
|
<!-- The local.properties file is created and updated by the 'android' tool.
|
||||||
|
It contains the path to the SDK. It should *NOT* be checked into
|
||||||
|
Version Control Systems. -->
|
||||||
|
<loadproperties srcFile="local.properties" />
|
||||||
|
|
||||||
|
<!-- The ant.properties file can be created by you. It is only edited by the
|
||||||
|
'android' tool to add properties to it.
|
||||||
|
This is the place to change some Ant specific build properties.
|
||||||
|
Here are some properties you may want to change/update:
|
||||||
|
|
||||||
|
source.dir
|
||||||
|
The name of the source directory. Default is 'src'.
|
||||||
|
out.dir
|
||||||
|
The name of the output directory. Default is 'bin'.
|
||||||
|
|
||||||
|
For other overridable properties, look at the beginning of the rules
|
||||||
|
files in the SDK, at tools/ant/build.xml
|
||||||
|
|
||||||
|
Properties related to the SDK location or the project target should
|
||||||
|
be updated using the 'android' tool with the 'update' action.
|
||||||
|
|
||||||
|
This file is an integral part of the build system for your
|
||||||
|
application and should be checked into Version Control Systems.
|
||||||
|
|
||||||
|
-->
|
||||||
|
<property file="ant.properties" />
|
||||||
|
|
||||||
|
<!-- The project.properties file is created and updated by the 'android'
|
||||||
|
tool, as well as ADT.
|
||||||
|
|
||||||
|
This contains project specific properties such as project target, and library
|
||||||
|
dependencies. Lower level build properties are stored in ant.properties
|
||||||
|
(or in .classpath for Eclipse projects).
|
||||||
|
|
||||||
|
This file is an integral part of the build system for your
|
||||||
|
application and should be checked into Version Control Systems. -->
|
||||||
|
<loadproperties srcFile="project.properties" />
|
||||||
|
|
||||||
|
<!-- quick check on sdk.dir -->
|
||||||
|
<fail
|
||||||
|
message="sdk.dir is missing. Make sure to generate local.properties using 'android update project'"
|
||||||
|
unless="sdk.dir"
|
||||||
|
/>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- extension targets. Uncomment the ones where you want to do custom work
|
||||||
|
in between standard targets -->
|
||||||
|
<!--
|
||||||
|
<target name="-pre-build">
|
||||||
|
</target>
|
||||||
|
<target name="-pre-compile">
|
||||||
|
</target>
|
||||||
|
|
||||||
|
/* This is typically used for code obfuscation.
|
||||||
|
Compiled code location: ${out.classes.absolute.dir}
|
||||||
|
If this is not done in place, override ${out.dex.input.absolute.dir} */
|
||||||
|
<target name="-post-compile">
|
||||||
|
</target>
|
||||||
|
-->
|
||||||
|
|
||||||
|
<!-- Import the actual build file.
|
||||||
|
|
||||||
|
To customize existing targets, there are two options:
|
||||||
|
- Customize only one target:
|
||||||
|
- copy/paste the target into this file, *before* the
|
||||||
|
<import> task.
|
||||||
|
- customize it to your needs.
|
||||||
|
- Customize the whole content of build.xml
|
||||||
|
- copy/paste the content of the rules files (minus the top node)
|
||||||
|
into this file, replacing the <import> task.
|
||||||
|
- customize to your needs.
|
||||||
|
|
||||||
|
***********************
|
||||||
|
****** IMPORTANT ******
|
||||||
|
***********************
|
||||||
|
In all cases you must update the value of version-tag below to read 'custom' instead of an integer,
|
||||||
|
in order to avoid having your file be overridden by tools such as "android update project"
|
||||||
|
-->
|
||||||
|
<!-- version-tag: 1 -->
|
||||||
|
<import file="${sdk.dir}/tools/ant/build.xml" />
|
||||||
|
|
||||||
|
</project>
|
||||||
10
Examples/android/extend/jni/Android.mk
Normal file
10
Examples/android/extend/jni/Android.mk
Normal file
|
|
@ -0,0 +1,10 @@
|
||||||
|
# File: Android.mk
|
||||||
|
LOCAL_PATH := $(call my-dir)
|
||||||
|
|
||||||
|
include $(CLEAR_VARS)
|
||||||
|
|
||||||
|
LOCAL_MODULE := example
|
||||||
|
LOCAL_SRC_FILES := example_wrap.cpp example.cpp
|
||||||
|
LOCAL_CFLAGS := -frtti
|
||||||
|
|
||||||
|
include $(BUILD_SHARED_LIBRARY)
|
||||||
1
Examples/android/extend/jni/Application.mk
Normal file
1
Examples/android/extend/jni/Application.mk
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
APP_STL := gnustl_static
|
||||||
4
Examples/android/extend/jni/example.cpp
Normal file
4
Examples/android/extend/jni/example.cpp
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
/* File : example.cxx */
|
||||||
|
|
||||||
|
#include "example.h"
|
||||||
|
|
||||||
56
Examples/android/extend/jni/example.h
Normal file
56
Examples/android/extend/jni/example.h
Normal file
|
|
@ -0,0 +1,56 @@
|
||||||
|
/* File : example.h */
|
||||||
|
|
||||||
|
#include <cstdio>
|
||||||
|
#include <iostream>
|
||||||
|
#include <vector>
|
||||||
|
#include <string>
|
||||||
|
#include <cmath>
|
||||||
|
|
||||||
|
class Employee {
|
||||||
|
private:
|
||||||
|
std::string name;
|
||||||
|
public:
|
||||||
|
Employee(const char* n): name(n) {}
|
||||||
|
virtual std::string getTitle() { return getPosition() + " " + getName(); }
|
||||||
|
virtual std::string getName() { return name; }
|
||||||
|
virtual std::string getPosition() const { return "Employee"; }
|
||||||
|
virtual ~Employee() { printf("~Employee() @ %p\n", this); }
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class Manager: public Employee {
|
||||||
|
public:
|
||||||
|
Manager(const char* n): Employee(n) {}
|
||||||
|
virtual std::string getPosition() const { return "Manager"; }
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class EmployeeList {
|
||||||
|
std::vector<Employee*> list;
|
||||||
|
public:
|
||||||
|
EmployeeList() {
|
||||||
|
list.push_back(new Employee("Bob"));
|
||||||
|
list.push_back(new Employee("Jane"));
|
||||||
|
list.push_back(new Manager("Ted"));
|
||||||
|
}
|
||||||
|
void addEmployee(Employee *p) {
|
||||||
|
list.push_back(p);
|
||||||
|
std::cout << "New employee added. Current employees are:" << std::endl;
|
||||||
|
std::vector<Employee*>::iterator i;
|
||||||
|
for (i=list.begin(); i!=list.end(); i++) {
|
||||||
|
std::cout << " " << (*i)->getTitle() << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const Employee *get_item(int i) {
|
||||||
|
return list[i];
|
||||||
|
}
|
||||||
|
~EmployeeList() {
|
||||||
|
std::vector<Employee*>::iterator i;
|
||||||
|
std::cout << "~EmployeeList, deleting " << list.size() << " employees." << std::endl;
|
||||||
|
for (i=list.begin(); i!=list.end(); i++) {
|
||||||
|
delete *i;
|
||||||
|
}
|
||||||
|
std::cout << "~EmployeeList empty." << std::endl;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
15
Examples/android/extend/jni/example.i
Normal file
15
Examples/android/extend/jni/example.i
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
/* File : example.i */
|
||||||
|
%module(directors="1") example
|
||||||
|
%{
|
||||||
|
#include "example.h"
|
||||||
|
%}
|
||||||
|
|
||||||
|
%include "std_vector.i"
|
||||||
|
%include "std_string.i"
|
||||||
|
|
||||||
|
/* turn on director wrapping for Manager */
|
||||||
|
%feature("director") Employee;
|
||||||
|
%feature("director") Manager;
|
||||||
|
|
||||||
|
%include "example.h"
|
||||||
|
|
||||||
10
Examples/android/extend/local.properties
Normal file
10
Examples/android/extend/local.properties
Normal file
|
|
@ -0,0 +1,10 @@
|
||||||
|
# This file is automatically generated by Android Tools.
|
||||||
|
# Do not modify this file -- YOUR CHANGES WILL BE ERASED!
|
||||||
|
#
|
||||||
|
# This file must *NOT* be checked in Version Control Systems,
|
||||||
|
# as it contains information specific to your local configuration.
|
||||||
|
|
||||||
|
# location of the SDK. This is only used by Ant
|
||||||
|
# For customization when using a Version Control System, please read the
|
||||||
|
# header note.
|
||||||
|
sdk.dir=/home/william/android/android-sdk-linux_x86
|
||||||
40
Examples/android/extend/proguard.cfg
Normal file
40
Examples/android/extend/proguard.cfg
Normal file
|
|
@ -0,0 +1,40 @@
|
||||||
|
-optimizationpasses 5
|
||||||
|
-dontusemixedcaseclassnames
|
||||||
|
-dontskipnonpubliclibraryclasses
|
||||||
|
-dontpreverify
|
||||||
|
-verbose
|
||||||
|
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*
|
||||||
|
|
||||||
|
-keep public class * extends android.app.Activity
|
||||||
|
-keep public class * extends android.app.Application
|
||||||
|
-keep public class * extends android.app.Service
|
||||||
|
-keep public class * extends android.content.BroadcastReceiver
|
||||||
|
-keep public class * extends android.content.ContentProvider
|
||||||
|
-keep public class * extends android.app.backup.BackupAgentHelper
|
||||||
|
-keep public class * extends android.preference.Preference
|
||||||
|
-keep public class com.android.vending.licensing.ILicensingService
|
||||||
|
|
||||||
|
-keepclasseswithmembernames class * {
|
||||||
|
native <methods>;
|
||||||
|
}
|
||||||
|
|
||||||
|
-keepclasseswithmembers class * {
|
||||||
|
public <init>(android.content.Context, android.util.AttributeSet);
|
||||||
|
}
|
||||||
|
|
||||||
|
-keepclasseswithmembers class * {
|
||||||
|
public <init>(android.content.Context, android.util.AttributeSet, int);
|
||||||
|
}
|
||||||
|
|
||||||
|
-keepclassmembers class * extends android.app.Activity {
|
||||||
|
public void *(android.view.View);
|
||||||
|
}
|
||||||
|
|
||||||
|
-keepclassmembers enum * {
|
||||||
|
public static **[] values();
|
||||||
|
public static ** valueOf(java.lang.String);
|
||||||
|
}
|
||||||
|
|
||||||
|
-keep class * implements android.os.Parcelable {
|
||||||
|
public static final android.os.Parcelable$Creator *;
|
||||||
|
}
|
||||||
11
Examples/android/extend/project.properties
Normal file
11
Examples/android/extend/project.properties
Normal file
|
|
@ -0,0 +1,11 @@
|
||||||
|
# This file is automatically generated by Android Tools.
|
||||||
|
# Do not modify this file -- YOUR CHANGES WILL BE ERASED!
|
||||||
|
#
|
||||||
|
# This file must be checked in Version Control Systems.
|
||||||
|
#
|
||||||
|
# To customize properties used by the Ant build system use,
|
||||||
|
# "ant.properties", and override values to adapt the script to your
|
||||||
|
# project structure.
|
||||||
|
|
||||||
|
# Project target.
|
||||||
|
target=android-8
|
||||||
25
Examples/android/extend/res/layout/main.xml
Normal file
25
Examples/android/extend/res/layout/main.xml
Normal file
|
|
@ -0,0 +1,25 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
>
|
||||||
|
<Button
|
||||||
|
android:id="@+id/RunButton"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Run..."
|
||||||
|
android:onClick="onRunButtonClick"
|
||||||
|
/>
|
||||||
|
<ScrollView
|
||||||
|
android:id="@+id/Scroller"
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
>
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/OutputText"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
/>
|
||||||
|
</ScrollView>
|
||||||
|
</LinearLayout>
|
||||||
4
Examples/android/extend/res/values/strings.xml
Normal file
4
Examples/android/extend/res/values/strings.xml
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<resources>
|
||||||
|
<string name="app_name">SwigExtend</string>
|
||||||
|
</resources>
|
||||||
|
|
@ -0,0 +1,108 @@
|
||||||
|
package org.swig.extendexample;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.TextView;
|
||||||
|
import android.widget.ScrollView;
|
||||||
|
import android.text.method.ScrollingMovementMethod;
|
||||||
|
|
||||||
|
public class SwigExtend extends Activity
|
||||||
|
{
|
||||||
|
TextView outputText = null;
|
||||||
|
ScrollView scroller = null;
|
||||||
|
|
||||||
|
/** Called when the activity is first created. */
|
||||||
|
@Override
|
||||||
|
public void onCreate(Bundle savedInstanceState)
|
||||||
|
{
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.main);
|
||||||
|
|
||||||
|
outputText = (TextView)findViewById(R.id.OutputText);
|
||||||
|
outputText.setText("Press 'Run' to start...\n");
|
||||||
|
outputText.setMovementMethod(new ScrollingMovementMethod());
|
||||||
|
|
||||||
|
scroller = (ScrollView)findViewById(R.id.Scroller);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onRunButtonClick(View view)
|
||||||
|
{
|
||||||
|
outputText.append("Started...\n");
|
||||||
|
nativeCall();
|
||||||
|
outputText.append("Finished!\n");
|
||||||
|
|
||||||
|
// Ensure scroll to end of text
|
||||||
|
scroller.post(new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
scroller.fullScroll(ScrollView.FOCUS_DOWN);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Calls into C/C++ code */
|
||||||
|
public void nativeCall()
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
// ----- Object creation -----
|
||||||
|
|
||||||
|
outputText.append( "Creating some objects:\n" );
|
||||||
|
Circle c = new Circle(10);
|
||||||
|
outputText.append( " Created circle " + c + "\n");
|
||||||
|
Square s = new Square(10);
|
||||||
|
outputText.append( " Created square " + s + "\n");
|
||||||
|
|
||||||
|
// ----- Access a static member -----
|
||||||
|
|
||||||
|
outputText.append( "\nA total of " + Shape.getNshapes() + " shapes were created\n" );
|
||||||
|
|
||||||
|
// ----- Member data access -----
|
||||||
|
|
||||||
|
// Notice how we can do this using functions specific to
|
||||||
|
// the 'Circle' class.
|
||||||
|
c.setX(20);
|
||||||
|
c.setY(30);
|
||||||
|
|
||||||
|
// Now use the same functions in the base class
|
||||||
|
Shape shape = s;
|
||||||
|
shape.setX(-10);
|
||||||
|
shape.setY(5);
|
||||||
|
|
||||||
|
outputText.append( "\nHere is their current position:\n" );
|
||||||
|
outputText.append( " Circle = (" + c.getX() + " " + c.getY() + ")\n" );
|
||||||
|
outputText.append( " Square = (" + s.getX() + " " + s.getY() + ")\n" );
|
||||||
|
|
||||||
|
// ----- Call some methods -----
|
||||||
|
|
||||||
|
outputText.append( "\nHere are some properties of the shapes:\n" );
|
||||||
|
Shape[] shapes = {c,s};
|
||||||
|
for (int i=0; i<shapes.length; i++)
|
||||||
|
{
|
||||||
|
outputText.append( " " + shapes[i].toString() + "\n" );
|
||||||
|
outputText.append( " area = " + shapes[i].area() + "\n" );
|
||||||
|
outputText.append( " perimeter = " + shapes[i].perimeter() + "\n" );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Notice how the area() and perimeter() functions really
|
||||||
|
// invoke the appropriate virtual method on each object.
|
||||||
|
|
||||||
|
// ----- Delete everything -----
|
||||||
|
|
||||||
|
outputText.append( "\nGuess I'll clean up now\n" );
|
||||||
|
|
||||||
|
// Note: this invokes the virtual destructor
|
||||||
|
// You could leave this to the garbage collector
|
||||||
|
c.delete();
|
||||||
|
s.delete();
|
||||||
|
|
||||||
|
outputText.append( Shape.getNshapes() + " shapes remain\n" );
|
||||||
|
outputText.append( "Goodbye\n" );
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
/** static constructor */
|
||||||
|
static {
|
||||||
|
System.loadLibrary("example");
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue