diff options
| author | Mathieu Malaterre <mathieu.malaterre@gmail.com> | 2012-01-20 14:08:59 +0000 |
|---|---|---|
| committer | Mathieu Malaterre <mathieu.malaterre@gmail.com> | 2012-01-20 14:08:59 +0000 |
| commit | 452403d393c50bd4b5cb8f96a907332e6e5e678c (patch) | |
| tree | 148e47933536bed28f1470e4b7714518f79f4a3c /applications/JavaOpenJPEG | |
| parent | fc268dff901855a27b7ebc3c1969e6c34c6c5694 (diff) | |
Build conditionally the java binding
Diffstat (limited to 'applications/JavaOpenJPEG')
| -rw-r--r-- | applications/JavaOpenJPEG/CMakeLists.txt | 58 | ||||
| -rw-r--r-- | applications/JavaOpenJPEG/JavaOpenJPEG.c | 8 | ||||
| -rw-r--r-- | applications/JavaOpenJPEG/Makefile | 14 |
3 files changed, 40 insertions, 40 deletions
diff --git a/applications/JavaOpenJPEG/CMakeLists.txt b/applications/JavaOpenJPEG/CMakeLists.txt index ecc8340d..2f4a481b 100644 --- a/applications/JavaOpenJPEG/CMakeLists.txt +++ b/applications/JavaOpenJPEG/CMakeLists.txt @@ -1,33 +1,47 @@ #JavaOpenJPEG/CMakeLists.txt # First thing define the common source: -SET(common_SRCS - ../codec/convert.c - ../codec/index.c - ../common/opj_getopt.c +SET(openjpegjni_SRCS + JavaOpenJPEGDecoder.c + JavaOpenJPEG.c ) +# JNI binding: +find_package(JNI REQUIRED) +include_directories(${JNI_INCLUDE_DIRS}) -# Headers file are located here: -INCLUDE_DIRECTORIES( +# required header file: +include_directories( ${OPENJPEG_SOURCE_DIR}/libopenjpeg - ${LCMS_INCLUDE_DIR} - ${PNG_INCLUDE_DIR} - ${ZLIB_INCLUDE_DIR} - ${TIFF_INCLUDE_DIR} + ${OPENJPEG_SOURCE_DIR}/applications/common + ${OPENJPEG_SOURCE_DIR}/applications/codec ) -# Loop over all executables: -FOREACH(exe j2k_to_image image_to_j2k) - ADD_EXECUTABLE(${exe} ${exe}.c ${common_SRCS}) - TARGET_LINK_LIBRARIES(${exe} ${OPJ_PREFIX}openjpeg ${TIFF_LIBRARIES} - ${PNG_LIBRARIES} ${ZLIB_LIBRARY} ${LCMS_LIB}) - # On unix you need to link to the math library: - IF(UNIX) - TARGET_LINK_LIBRARIES(${exe} -lm) - ENDIF(UNIX) - # Install exe - INSTALL_TARGETS(/bin/ ${exe}) -ENDFOREACH(exe) +add_library(openjpegjni MODULE + ${openjpegjni_SRCS} + ) + +# build jar: +FIND_PACKAGE(Java 1.5 REQUIRED) # javac, jar + +# build dep list: +file(GLOB java_srcs "java-sources/org/openJpeg/*.java") +# make sure target javac dir exists: +file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/classes) +# Build java +ADD_CUSTOM_COMMAND( + OUTPUT ${LIBRARY_OUTPUT_PATH}/openjpeg.jar + COMMAND ${Java_JAVAC_EXECUTABLE} -sourcepath "${CMAKE_CURRENT_SOURCE_DIR}/java-sources" + ${java_srcs} -d ${CMAKE_CURRENT_BINARY_DIR}/classes + COMMAND ${Java_JAR_EXECUTABLE} cvf ${LIBRARY_OUTPUT_PATH}/openjpeg.jar org + WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/classes + DEPENDS ${java_srcs} + COMMENT "javac *.java; jar cvf -> openjpeg.jar" +) +# name the target +ADD_CUSTOM_TARGET(OpenJPEGJavaJar ALL + DEPENDS ${LIBRARY_OUTPUT_PATH}/openjpeg.jar + COMMENT "building openjpeg.jar" +) diff --git a/applications/JavaOpenJPEG/JavaOpenJPEG.c b/applications/JavaOpenJPEG/JavaOpenJPEG.c index eea41c25..3f8e2ee7 100644 --- a/applications/JavaOpenJPEG/JavaOpenJPEG.c +++ b/applications/JavaOpenJPEG/JavaOpenJPEG.c @@ -380,7 +380,7 @@ static int initialise_4K_poc(opj_poc_t *POC, int numres){ }
void cinema_parameters(opj_cparameters_t *parameters){
- parameters->tile_size_on = false;
+ parameters->tile_size_on = OPJ_FALSE;
parameters->cp_tdx=1;
parameters->cp_tdy=1;
@@ -663,7 +663,7 @@ int parse_cmdline_encoder(int argc, char **argv, opj_cparameters_t *parameters, case 't': /* tiles */
{
sscanf(opj_optarg, "%d,%d", ¶meters->cp_tdx, ¶meters->cp_tdy);
- parameters->tile_size_on = true;
+ parameters->tile_size_on = OPJ_TRUE;
}
break;
@@ -1628,7 +1628,7 @@ opj_image_t* loadImage(opj_cparameters_t *parameters, JNIEnv *env, jobject obj, jbyte *jbBody;
jshort *jsBody;
jint *jiBody;
- boolean isCopy;
+ jboolean isCopy;
// Image width, height and depth
fid = (*env)->GetFieldID(env, cls,"width", "I");
@@ -1776,7 +1776,7 @@ opj_image_t* loadImage(opj_cparameters_t *parameters, JNIEnv *env, jobject obj, JNIEXPORT jlong JNICALL Java_org_openJpeg_OpenJPEGJavaEncoder_internalEncodeImageToJ2K(JNIEnv *env, jobject obj, jobjectArray javaParameters) {
int argc; /* To simulate the command line parameters (taken from the javaParameters variable) and be able to re-use the */
char **argv; /* 'parse_cmdline_decoder' method taken from the j2k_to_image project */
- bool bSuccess;
+ opj_bool bSuccess;
opj_cparameters_t parameters; /* compression parameters */
img_fol_t img_fol;
opj_event_mgr_t event_mgr; /* event manager */
diff --git a/applications/JavaOpenJPEG/Makefile b/applications/JavaOpenJPEG/Makefile deleted file mode 100644 index 74d94056..00000000 --- a/applications/JavaOpenJPEG/Makefile +++ /dev/null @@ -1,14 +0,0 @@ -# Makefile for the main OpenJPEG codecs: j2k_to_image and image_to_j2k - -CFLAGS = -O3 -lstdc++ # -g -p -pg - -all: j2k_to_image image_to_j2k - -j2k_to_image: j2k_to_image.c ../libopenjpeg.a - gcc $(CFLAGS) ../common/opj_getopt.c convert.c j2k_to_image.c -o j2k_to_image -L.. -lopenjpeg -I ../libopenjpeg/ -lm -ltiff - -image_to_j2k: image_to_j2k.c ../libopenjpeg.a - gcc $(CFLAGS) ../common/opj_getopt.c convert.c image_to_j2k.c -o image_to_j2k -L.. -lopenjpeg -I ../libopenjpeg/ -lm -ltiff - -clean: - rm -f j2k_to_image image_to_j2k |
