mirror of
https://github.com/eclipse/upm.git
synced 2025-03-15 04:57:30 +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"
|
||||
|
||||
%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 "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"
|
||||
|
@ -808,6 +808,23 @@ namespace upm {
|
||||
*/
|
||||
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
|
||||
*
|
||||
|
@ -100,3 +100,12 @@ void MPU9150::getMagnetometer(float *x, float *y, float *z)
|
||||
if (z)
|
||||
*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);
|
||||
|
||||
#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:
|
||||
// magnetometer instance
|
||||
|
Loading…
x
Reference in New Issue
Block a user