add pick to view tests
This commit is contained in:
@@ -1,3 +1,5 @@
|
||||
import 'dart:async';
|
||||
|
||||
import 'package:test/test.dart';
|
||||
import 'package:thermion_dart/thermion_dart.dart';
|
||||
import 'package:vector_math/vector_math_64.dart';
|
||||
@@ -17,7 +19,8 @@ void main() async {
|
||||
var viewer = await testHelper.createViewer();
|
||||
|
||||
final texture = await testHelper.createTexture(500, 500);
|
||||
final renderTarget = await viewer.createRenderTarget(500, 500, texture.metalTextureAddress);
|
||||
final renderTarget = await viewer.createRenderTarget(
|
||||
500, 500, texture.metalTextureAddress);
|
||||
viewer.setRenderTarget(renderTarget);
|
||||
|
||||
await viewer.setBackgroundColor(1.0, 0, 0, 1);
|
||||
@@ -76,14 +79,15 @@ void main() async {
|
||||
|
||||
var mainCamera = await viewer.getMainCamera();
|
||||
mainCamera.setTransform(Matrix4.translation(Vector3(0, 0, 5)));
|
||||
final swapChain = await viewer.createSwapChain(1, 1);
|
||||
final swapChain = await viewer.createHeadlessSwapChain(1, 1);
|
||||
await testHelper.capture(
|
||||
viewer, "create_swapchain_default_view_default_swapchain");
|
||||
|
||||
final view = await viewer.createView();
|
||||
|
||||
final texture = await testHelper.createTexture(200, 400);
|
||||
final renderTarget = await viewer.createRenderTarget(200, 400, texture.metalTextureAddress);
|
||||
final renderTarget = await viewer.createRenderTarget(
|
||||
200, 400, texture.metalTextureAddress);
|
||||
await view.setRenderTarget(renderTarget);
|
||||
|
||||
await view.updateViewport(200, 400);
|
||||
@@ -100,5 +104,30 @@ void main() async {
|
||||
|
||||
await viewer.dispose();
|
||||
});
|
||||
|
||||
test('pick', () async {
|
||||
var viewer = await testHelper.createViewer(
|
||||
bg: kRed, cameraPosition: Vector3(0, 0, 5));
|
||||
|
||||
final cube = await viewer.createGeometry(GeometryHelper.cube());
|
||||
|
||||
final completer = Completer();
|
||||
late StreamSubscription listener;
|
||||
listener = viewer.pickResult.listen((result) async {
|
||||
completer.complete(result.entity);
|
||||
await listener.cancel();
|
||||
});
|
||||
|
||||
viewer.pick(250, 250);
|
||||
|
||||
for (int i = 0; i < 10; i++) {
|
||||
await viewer.requestFrame();
|
||||
await Future.delayed(Duration(milliseconds: 100));
|
||||
}
|
||||
|
||||
expect(completer.isCompleted, true);
|
||||
expect(await completer.future, cube);
|
||||
await viewer.dispose();
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user