implement remaining asset methods
This commit is contained in:
@@ -134,13 +134,17 @@ extern "C" {
|
|||||||
((SceneAsset*)asset)->transformToUnitCube();
|
((SceneAsset*)asset)->transformToUnitCube();
|
||||||
}
|
}
|
||||||
|
|
||||||
// void set_position(void* asset, float x, float y, float z) {
|
void set_position(void* asset, float x, float y, float z) {
|
||||||
// ((SceneAsset*)asset)->setPosition(x, y, z);
|
((SceneAsset*)asset)->setPosition(x, y, z);
|
||||||
// }
|
}
|
||||||
|
|
||||||
// void set_rotation(void* asset, float rads, float x, float y, float z) {
|
void set_rotation(void* asset, float rads, float x, float y, float z) {
|
||||||
// ((SceneAsset*)asset)->setRotation(rads, x, y, z);
|
((SceneAsset*)asset)->setRotation(rads, x, y, z);
|
||||||
// }
|
}
|
||||||
|
|
||||||
|
void stop_animation(void* asset, int index) {
|
||||||
|
((SceneAsset*)asset)->stopAnimation(index);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -53,4 +53,6 @@ void set_position(void* asset, float x, float y, float z);
|
|||||||
|
|
||||||
void set_rotation(void* asset, float rads, float x, float y, float z);
|
void set_rotation(void* asset, float rads, float x, float y, float z);
|
||||||
|
|
||||||
|
void stop_animation(void* asset, int index);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -204,7 +204,7 @@ public class SwiftPolyvoxFilamentPlugin: NSObject, FlutterPlugin, FlutterTexture
|
|||||||
let args = call.arguments as! Array<Any?>
|
let args = call.arguments as! Array<Any?>
|
||||||
let assetPtr = UnsafeMutableRawPointer.init(bitPattern: args[0] as! Int)
|
let assetPtr = UnsafeMutableRawPointer.init(bitPattern: args[0] as! Int)
|
||||||
let animationIndex = args[1] as! Int32
|
let animationIndex = args[1] as! Int32
|
||||||
// stop_animation(assetPtr, animationIndex) // TODO
|
stop_animation(assetPtr, animationIndex) // TODO
|
||||||
result("OK");
|
result("OK");
|
||||||
case "getTargetNames":
|
case "getTargetNames":
|
||||||
let args = call.arguments as! Array<Any?>
|
let args = call.arguments as! Array<Any?>
|
||||||
@@ -254,30 +254,42 @@ public class SwiftPolyvoxFilamentPlugin: NSObject, FlutterPlugin, FlutterTexture
|
|||||||
animate_weights(assetPtr, UnsafeMutablePointer<Float>.init(mutating:$0.baseAddress), Int32(numWeights), Int32(numFrames), Float(frameLenInMs))
|
animate_weights(assetPtr, UnsafeMutablePointer<Float>.init(mutating:$0.baseAddress), Int32(numWeights), Int32(numFrames), Float(frameLenInMs))
|
||||||
}
|
}
|
||||||
result("OK")
|
result("OK")
|
||||||
|
case "panStart":
|
||||||
|
let args = call.arguments as! Array<Any>
|
||||||
|
grab_begin(self.viewer, args[0] as! Int32, args[1] as! Int32, true)
|
||||||
|
result("OK")
|
||||||
|
case "panUpdate":
|
||||||
|
let args = call.arguments as! Array<Any>
|
||||||
|
grab_update(self.viewer, args[0] as! Int32, args[1] as! Int32)
|
||||||
|
result("OK")
|
||||||
|
case "panEnd":
|
||||||
|
grab_end(self.viewer)
|
||||||
|
result("OK")
|
||||||
|
case "rotateStart":
|
||||||
|
let args = call.arguments as! Array<Any>
|
||||||
|
grab_begin(self.viewer, args[0] as! Int32, args[1] as! Int32, false)
|
||||||
|
result("OK")
|
||||||
|
case "rotateUpdate":
|
||||||
|
let args = call.arguments as! Array<Any>
|
||||||
|
grab_update(self.viewer, args[0] as! Int32, args[1] as! Int32)
|
||||||
|
result("OK")
|
||||||
|
case "rotateEnd":
|
||||||
|
grab_end(self.viewer)
|
||||||
|
result("OK")
|
||||||
|
case "setPosition":
|
||||||
|
let args = call.arguments as! Array<Any>
|
||||||
|
let assetPtr = UnsafeMutableRawPointer.init(bitPattern: args[0] as! Int)
|
||||||
|
let x = Float(args[1] as! Double)
|
||||||
|
set_position(assetPtr, x, Float(args[2] as! Double), Float(args[3] as! Double))
|
||||||
|
result("OK")
|
||||||
|
case "setRotation":
|
||||||
|
let args = call.arguments as! Array<Any>
|
||||||
|
let assetPtr = UnsafeMutableRawPointer.init(bitPattern: args[0] as! Int)
|
||||||
|
set_rotation(assetPtr, Float(args[1] as! Double), Float(args[2] as! Double), Float(args[3] as! Double), Float(args[4] as! Double))
|
||||||
|
result("OK")
|
||||||
default:
|
default:
|
||||||
result(FlutterMethodNotImplemented)
|
result(FlutterMethodNotImplemented)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// } else if([@"panStart" isEqualToString:call.method]) {
|
|
||||||
// _viewer->manipulator->grabBegin([call.arguments[0] intValue], [call.arguments[1] intValue], true);
|
|
||||||
// result(@"OK");
|
|
||||||
// } else if([@"panUpdate" isEqualToString:call.method]) {
|
|
||||||
// _viewer->manipulator->grabUpdate([call.arguments[0] intValue], [call.arguments[1] intValue]);
|
|
||||||
// result(@"OK");
|
|
||||||
// } else if([@"panEnd" isEqualToString:call.method]) {
|
|
||||||
// _viewer->manipulator->grabEnd();
|
|
||||||
// result(@"OK");
|
|
||||||
// } else if([@"rotateStart" isEqualToString:call.method]) {
|
|
||||||
// _viewer->manipulator->grabBegin([call.arguments[0] intValue], [call.arguments[1] intValue], false);
|
|
||||||
// result(@"OK");
|
|
||||||
// } else if([@"rotateUpdate" isEqualToString:call.method]) {
|
|
||||||
// _viewer->manipulator->grabUpdate([call.arguments[0] intValue], [call.arguments[1] intValue]);
|
|
||||||
// result(@"OK");
|
|
||||||
// } else if([@"rotateEnd" isEqualToString:call.method]) {
|
|
||||||
// _viewer->manipulator->grabEnd();
|
|
||||||
// result(@"OK");
|
|
||||||
// } else
|
|
||||||
|
|||||||
Reference in New Issue
Block a user