Skip to content
GitLab
Explore
Projects
Groups
Snippets
Projects
Groups
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in
Toggle navigation
Menu
Open sidebar
GeoVistoogsi
AR
Commits
a372067f
Commit
a372067f
authored
4 months ago
by
Percen
Browse files
Options
Download
Email Patches
Plain Diff
Update public/index.html
parent
967d02f8
master
21caog1bif-master-patch-76399
21caog1bif-master-patch-83779
21caog1bif-master-patch-96693
1 merge request
!73
Update public/index.html
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
public/index.html
+29
-36
public/index.html
with
29 additions
and
36 deletions
+29
-36
public/index.html
+
29
-
36
View file @
a372067f
...
...
@@ -24,7 +24,7 @@
</head>
<body>
<script>
let
selectedModel
=
'
robot
'
;
// Standardauswahl
let
selectedModel
=
'
robot
'
;
let
models
=
{};
let
reticle
;
let
currentModel
=
null
;
...
...
@@ -43,7 +43,7 @@
camera
=
new
THREE
.
PerspectiveCamera
();
camera
.
matrixAutoUpdate
=
false
;
// Licht
hinzufügen
// Licht
const
light
=
new
THREE
.
DirectionalLight
(
0xffffff
,
1
);
light
.
position
.
set
(
10
,
10
,
10
);
scene
.
add
(
light
);
...
...
@@ -56,7 +56,7 @@
scene
.
add
(
reticle
);
});
// Modelle
laden
// Modelle
loader
.
load
(
"
https://threejs.org/examples/models/gltf/RobotExpressive/RobotExpressive.glb
"
,
(
gltf
)
=>
{
models
.
robot
=
gltf
.
scene
;
});
...
...
@@ -64,15 +64,13 @@
models
.
flower
=
gltf
.
scene
;
});
//
A
R-Session
starten
//
X
R-Session
const
session
=
await
navigator
.
xr
.
requestSession
(
'
immersive-ar
'
,
{
requiredFeatures
:
[
'
hit-test
'
]
});
session
.
updateRenderState
({
baseLayer
:
new
XRWebGLLayer
(
session
,
gl
)
});
const
referenceSpace
=
await
session
.
requestReferenceSpace
(
'
local
'
);
const
viewerSpace
=
await
session
.
requestReferenceSpace
(
'
viewer
'
);
hitTestSource
=
await
session
.
requestHitTestSource
({
space
:
viewerSpace
});
session
.
addEventListener
(
'
select
'
,
onPlaceModel
);
session
.
requestAnimationFrame
(
onXRFrame
);
function
onXRFrame
(
time
,
frame
)
{
...
...
@@ -102,51 +100,46 @@
}
}
function
onPlaceModel
()
{
if
(
isSwipe
)
return
;
// Verhindere Platzieren bei Swipe
if
(
reticle
&&
reticle
.
visible
&&
models
[
selectedModel
])
{
const
newModel
=
models
[
selectedModel
].
clone
();
newModel
.
position
.
copy
(
reticle
.
position
);
scene
.
add
(
newModel
);
}
}
// Swipe-Logik
let
startX
=
0
,
endX
=
0
;
const
threshold
=
50
;
// Mindestdistanz für Swipe
// Touch-Logik zur Unterscheidung zwischen Swipe und Tap
let
startX
=
0
,
endX
=
0
,
isSwiping
=
false
;
const
threshold
=
50
;
document
.
body
.
addEventListener
(
'
touchstart
'
,
(
e
)
=>
{
startX
=
e
.
touches
[
0
].
clientX
;
isSwip
e
=
false
;
isSwip
ing
=
false
;
});
document
.
body
.
addEventListener
(
'
touchend
'
,
(
e
)
=>
{
endX
=
e
.
changedTouches
[
0
].
clientX
;
const
deltaX
=
endX
-
startX
;
if
(
Math
.
abs
(
deltaX
)
>
threshold
)
{
isSwipe
=
true
;
// Swipe erkannt
if
(
deltaX
>
0
)
{
document
.
body
.
addEventListener
(
'
touchmove
'
,
(
e
)
=>
{
const
moveX
=
e
.
touches
[
0
].
clientX
;
if
(
Math
.
abs
(
moveX
-
startX
)
>
threshold
)
{
isSwiping
=
true
;
if
(
moveX
>
startX
)
{
switchModel
(
'
next
'
);
}
else
{
switchModel
(
'
previous
'
);
}
startX
=
moveX
;
// Verhindert mehrfaches Swipen bei einem langen Touchmove
}
});
function
switchModel
(
direction
)
{
if
(
currentModel
)
scene
.
remove
(
currentModel
);
document
.
body
.
addEventListener
(
'
touchend
'
,
()
=>
{
if
(
!
isSwiping
)
{
placeModel
();
}
});
if
(
direction
===
'
next
'
)
{
selectedModel
=
selectedModel
===
'
robot
'
?
'
flower
'
:
'
robot
'
;
}
else
if
(
direction
===
'
previous
'
)
{
selectedModel
=
selectedModel
===
'
robot
'
?
'
flower
'
:
'
robot
'
;
function
placeModel
()
{
if
(
reticle
&&
reticle
.
visible
&&
models
[
selectedModel
])
{
const
newModel
=
models
[
selectedModel
].
clone
();
newModel
.
position
.
copy
(
reticle
.
position
);
scene
.
add
(
newModel
);
}
}
currentModel
=
models
[
selectedModel
].
clone
();
currentModel
.
position
.
copy
(
reticle
.
position
);
scene
.
add
(
currentModel
);
function
switchModel
(
direction
)
{
selectedModel
=
direction
===
'
next
'
?
(
selectedModel
===
'
robot
'
?
'
flower
'
:
'
robot
'
)
:
(
selectedModel
===
'
robot
'
?
'
flower
'
:
'
robot
'
);
}
if
(
navigator
.
xr
)
{
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment
Menu
Explore
Projects
Groups
Snippets