mirror of
https://github.com/eclipse/upm.git
synced 2025-03-24 01:10:22 +03:00
java: fix return types and arrays for mpu60x0 and mpu9150
Signed-off-by: Petre Eftime <petre.p.eftime@intel.com> Signed-off-by: Mihai Tudor Panu <mihai.tudor.panu@intel.com>
This commit is contained in:
parent
83cb6dc2fd
commit
7afd1f3fc1
@ -9,18 +9,45 @@
|
|||||||
%include "../IsrCallback.h"
|
%include "../IsrCallback.h"
|
||||||
|
|
||||||
%apply int {mraa::Edge};
|
%apply int {mraa::Edge};
|
||||||
%apply float *INOUT { float *x, float *y, float *z };
|
|
||||||
%apply signed char[] {uint8_t *};
|
|
||||||
|
|
||||||
%{
|
%{
|
||||||
#include "mpu60x0.h"
|
#include "mpu60x0.h"
|
||||||
%}
|
|
||||||
|
|
||||||
%include "mpu60x0.h"
|
|
||||||
|
|
||||||
|
|
||||||
%{
|
|
||||||
#include "mpu9150.h"
|
#include "mpu9150.h"
|
||||||
%}
|
%}
|
||||||
|
|
||||||
|
|
||||||
|
%typemap(jni) float * "jfloatArray"
|
||||||
|
%typemap(jstype) float * "float[]"
|
||||||
|
%typemap(jtype) float * "float[]"
|
||||||
|
|
||||||
|
%typemap(javaout) float * {
|
||||||
|
return $jnicall;
|
||||||
|
}
|
||||||
|
|
||||||
|
%typemap(out) float * {
|
||||||
|
$result = JCALL1(NewFloatArray, jenv, 3);
|
||||||
|
JCALL4(SetFloatArrayRegion, jenv, $result, 0, 3, $1);
|
||||||
|
delete [] $1;
|
||||||
|
}
|
||||||
|
|
||||||
|
%ignore getAccelerometer(float *, float *, float *);
|
||||||
|
%ignore getGyroscope(float *, float *, float *);
|
||||||
|
%ignore getMagnetometer(float *, float *, float *);
|
||||||
|
|
||||||
|
%typemap(jni) (uint8_t *buf, int len) "jbyteArray";
|
||||||
|
%typemap(jtype) (uint8_t *buf, int len) "byte[]";
|
||||||
|
%typemap(jstype) (uint8_t *buf, int len) "byte[]";
|
||||||
|
|
||||||
|
%typemap(javain) (uint8_t *buf, int len) "$javainput";
|
||||||
|
|
||||||
|
%typemap(in) (uint8_t *buf, int len) {
|
||||||
|
$1 = (uint8_t *) JCALL2(GetByteArrayElements, jenv, $input, NULL);
|
||||||
|
$2 = JCALL1(GetArrayLength, jenv, $input);
|
||||||
|
}
|
||||||
|
|
||||||
|
%typemap(freearg) (uint8_t *buf, int len) {
|
||||||
|
JCALL3(ReleaseByteArrayElements, jenv, $input, (jbyte *)$1, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
%include "mpu60x0.h"
|
||||||
%include "mpu9150.h"
|
%include "mpu9150.h"
|
||||||
|
@ -808,6 +808,23 @@ namespace upm {
|
|||||||
*/
|
*/
|
||||||
void getGyroscope(float *x, float *y, float *z);
|
void getGyroscope(float *x, float *y, float *z);
|
||||||
|
|
||||||
|
#ifdef SWIGJAVA
|
||||||
|
/**
|
||||||
|
* get the accelerometer values
|
||||||
|
*
|
||||||
|
* @return Array containing X, Y, Z accelerometer values
|
||||||
|
*/
|
||||||
|
float *getAccelerometer();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* get the gyroscope values
|
||||||
|
*
|
||||||
|
* @return Array containing X, Y, Z gyroscope values
|
||||||
|
*/
|
||||||
|
float *getGyroscope();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* get the temperature value
|
* get the temperature value
|
||||||
*
|
*
|
||||||
|
@ -100,3 +100,12 @@ void MPU9150::getMagnetometer(float *x, float *y, float *z)
|
|||||||
if (z)
|
if (z)
|
||||||
*z = mz;
|
*z = mz;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef SWIGJAVA
|
||||||
|
float *MPU9150::getMagnetometer()
|
||||||
|
{
|
||||||
|
float *v = new float[3];
|
||||||
|
getMagnetometer(&v[0], &v[1], &v[2]);
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
@ -106,6 +106,17 @@ namespace upm {
|
|||||||
*/
|
*/
|
||||||
void getMagnetometer(float *x, float *y, float *z);
|
void getMagnetometer(float *x, float *y, float *z);
|
||||||
|
|
||||||
|
#ifdef SWIGJAVA
|
||||||
|
/**
|
||||||
|
* Return the compensated values for the x, y, and z axes. The
|
||||||
|
* unit of measurement is in micro-teslas (uT).
|
||||||
|
*
|
||||||
|
* @return Array containing X, Y, Z magnetometer values
|
||||||
|
*/
|
||||||
|
float *getMagnetometer();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// magnetometer instance
|
// magnetometer instance
|
||||||
|
Loading…
x
Reference in New Issue
Block a user