Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Iotroci 8819 #271

Merged
merged 6 commits into from
Oct 7, 2022
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions packages/scene-composer/jest.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,12 @@ export default merge.recursive(tsPreset, awsuiPreset, {
'!src/**/index.ts',
'!src/**/*.d.ts',
'!src/**/__snapshots__/*',
'!src/assets/**/*',
'!src/three/GLTFLoader.js',
'!src/three/tiles3d/TilesRenderer.js',
'!src/three/tiles3d/TilesRendererBase.js',
'!src/utils/sceneDocumentSnapshotCreator.ts',
'!src/augmentations/components/three-fiber/viewpoint/ViewCursorWidget.tsx', // Skipping as this is around mouse movement & is interaction based. Should be covered in end-to-end test or manual testing.
],
coverageReporters: [
'json',
Expand Down
8 changes: 4 additions & 4 deletions packages/scene-composer/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -154,10 +154,10 @@
"jest": {
"coverageThreshold": {
"global": {
"lines": 76.64,
"statements": 75.75,
"functions": 76.03,
"branches": 62.22,
"lines": 77.21,
"statements": 76.35,
"functions": 76.81,
"branches": 63.40,
"branchesTrue": 100
}
}
Expand Down
2 changes: 1 addition & 1 deletion packages/scene-composer/src/assets/viewpoints/IconSvgs.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ export const SelectedViewpointSvgString = `
`;

export const ViewCursorMoveSvgString = `
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'>
<svg width='10' height='10' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'>
<g fill='none'>
<circle cx='5' cy='5' r='5' fill='white' />
</g>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { Node, Object3DNode } from '@react-three/fiber';

import { Anchor, ViewCursor, Viewpoint } from './three';
import { Anchor } from './three';
import { WidgetSprite, WidgetVisual } from './three/visuals';

export type AnchorProps = Object3DNode<Anchor, typeof Anchor>;
Expand All @@ -9,10 +9,6 @@ export type WidgetVisualProps = Node<WidgetVisual, typeof WidgetVisual>;

export type WidgetSpriteProps = Node<WidgetSprite, typeof WidgetSprite>;

export type ViewpointProps = Object3DNode<Viewpoint, typeof Viewpoint>;

export type ViewCursorProps = Object3DNode<ViewCursor, typeof ViewCursor>;

/**
* Adds the Anchor type and props to the JSX.IntrinsicElements namespace
*/
Expand All @@ -23,8 +19,6 @@ declare global {
anchor: AnchorProps;
widgetVisual: WidgetVisualProps;
widgetSprite: WidgetSpriteProps;
viewpoint: ViewpointProps;
viewCursor: ViewCursorProps;
}
}
}

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,76 +1,62 @@
import * as THREE from 'three';
import React, { useContext, useEffect, useMemo, useRef } from 'react';
import { extend, useLoader, useThree } from '@react-three/fiber';
import { SVGLoader, SVGResult } from 'three-stdlib';
import React, { useCallback, useContext, useEffect, useMemo, useRef } from 'react';
import { useFrame, useLoader, useThree } from '@react-three/fiber';
import { Mesh as THREEMesh, Object3D as THREEObject3D, Vector3 as THREEVector3 } from 'three';
import { SVGLoader } from 'three-stdlib';

import { ViewCursorMoveIcon, ViewCursorEditIcon } from '../../../../assets';
import svgIconToWidgetVisual from '../common/SvgIconToWidgetVisual';
import { WidgetVisual } from '../../../three/visuals';
import { ViewCursor, Viewpoint, ViewpointState } from '../../../three';
import { convertSvgToMesh } from '../../../../utils/svgUtils';
import { getIntersectionTransform } from '../../../../utils/raycastUtils';
import { sceneComposerIdContext } from '../../../../common/sceneComposerIdContext';
import { useEditorState } from '../../../../store';
import { ViewCursorEditIcon, ViewCursorMoveIcon } from '../../../../assets';

// Adds the custom objects to React Three Fiber
extend({ ViewCursor, Viewpoint, WidgetVisual });

const AsyncLoadViewCursorWidget: React.FC = () => {
export const ViewCursorWidget = () => {
const ref = useRef<THREEObject3D>(null);
const { gl } = useThree();
const sceneComposerId = useContext(sceneComposerIdContext);
const { cursorPosition, cursorLookAt, cursorVisible, cursorStyle } = useEditorState(sceneComposerId);
const viewCursorRef = useRef<Viewpoint>(null);
const { camera } = useThree();

const moveVisual = useMemo(() => {
const svgData: SVGResult = useLoader(SVGLoader, ViewCursorMoveIcon.dataUri);
return svgIconToWidgetVisual(svgData, ViewpointState.Deselected, false, { userData: { isCursor: true } });
}, []);

const editVisual = useMemo(() => {
const svgData: SVGResult = useLoader(SVGLoader, ViewCursorEditIcon.dataUri);
return svgIconToWidgetVisual(svgData, ViewpointState.Selected, false, { userData: { isCursor: true } });
}, []);

useEffect(() => {
if (viewCursorRef.current) {
viewCursorRef.current.lookAt(cursorLookAt);
viewCursorRef.current.rotation.z = camera.rotation.z; // Prevent spinning and always be straight up and down
const { addingWidget, cursorVisible, cursorStyle, setAddingWidget, setCursorVisible, setCursorStyle } =
useEditorState(sceneComposerId);
const svg = cursorStyle === 'edit' ? ViewCursorEditIcon : ViewCursorMoveIcon;
const data = useLoader(SVGLoader, svg.dataUri);

const esc = useCallback(() => {
gl.domElement.addEventListener('keyup', (e: KeyboardEvent) => {
if (e.key === 'Escape' && !!addingWidget) {
setAddingWidget(undefined);
}
});
return gl.domElement?.removeEventListener('keyup', setAddingWidget as any);
}, [addingWidget]);

const shape = useMemo(() => {
return convertSvgToMesh(data);
}, [data]);

/* istanbul ignore next */
useFrame(({ raycaster, scene }) => {
const sceneMeshes: THREEObject3D[] = [];
scene.traverse((child) => {
return shape.id !== child.id && (child as THREEMesh).isMesh && child.type !== 'TransformControlsPlane'
? sceneMeshes.push(child as THREEMesh)
: null;
});
const intersects = raycaster.intersectObjects(sceneMeshes, false);
if (intersects.length) {
const n = getIntersectionTransform(intersects[0]);
shape.lookAt(n.normal as THREEVector3);
shape.position.copy(n.position);
}
}, [cursorLookAt]);
});

useEffect(() => {
if (viewCursorRef.current) {
viewCursorRef.current.traverse((child) => {
const mesh = child as THREE.Mesh;

if (mesh.material) {
if (Array.isArray(mesh.material)) {
mesh.material.forEach((material) => {
material.depthFunc = THREE.AlwaysDepth;
});
} else {
(mesh.material as THREE.Material).depthFunc = THREE.AlwaysDepth;
}
}
});
}
}, [viewCursorRef]);

return (
<viewCursor
ref={viewCursorRef}
isSelected={cursorStyle === 'edit'}
position={cursorPosition}
visible={cursorVisible}
>
{moveVisual}
{editVisual}
</viewCursor>
);
};
setCursorVisible(!!addingWidget);
setCursorStyle(addingWidget ? 'edit' : 'move');
esc();
gl.domElement.style.cursor = addingWidget ? 'none' : 'auto';
}, [addingWidget]);

export const ViewCursorWidget: React.FC = () => {
return (
<React.Suspense fallback={null}>
<AsyncLoadViewCursorWidget />
{cursorVisible && <primitive ref={ref} object={shape} name='ViewCursorWidget' />}
</React.Suspense>
);
};
73 changes: 0 additions & 73 deletions packages/scene-composer/src/augmentations/three/Viewpoint.ts

This file was deleted.

1 change: 0 additions & 1 deletion packages/scene-composer/src/augmentations/three/index.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
export * from './Anchor';
export * from './Viewpoint';
Loading