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
d2a9e9f9
Commit
d2a9e9f9
authored
4 months ago
by
Percen
Browse files
Options
Download
Email Patches
Plain Diff
Update public/index.html
parent
2d4f1d95
master
21caog1bif-master-patch-76399
21caog1bif-master-patch-83779
21caog1bif-master-patch-96693
1 merge request
!80
Update public/index.html
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
public/index.html
+20
-6
public/index.html
with
20 additions
and
6 deletions
+20
-6
public/index.html
+
20
-
6
View file @
d2a9e9f9
...
...
@@ -27,16 +27,17 @@
let
selectedModel
=
'
flower
'
;
// Standardauswahl
let
models
=
{};
let
reticle
;
let
scene
,
camera
,
renderer
,
session
;
async
function
activateXR
()
{
const
canvas
=
document
.
createElement
(
'
canvas
'
);
document
.
body
.
appendChild
(
canvas
);
const
gl
=
canvas
.
getContext
(
'
webgl
'
,
{
xrCompatible
:
true
});
const
renderer
=
new
THREE
.
WebGLRenderer
({
alpha
:
true
,
canvas
,
context
:
gl
});
renderer
=
new
THREE
.
WebGLRenderer
({
alpha
:
true
,
canvas
,
context
:
gl
});
renderer
.
autoClear
=
false
;
const
scene
=
new
THREE
.
Scene
();
const
camera
=
new
THREE
.
PerspectiveCamera
();
scene
=
new
THREE
.
Scene
();
camera
=
new
THREE
.
PerspectiveCamera
();
camera
.
matrixAutoUpdate
=
false
;
// Licht hinzufügen
...
...
@@ -61,7 +62,7 @@
});
// AR-Session starten
const
session
=
await
navigator
.
xr
.
requestSession
(
'
immersive-ar
'
,
{
requiredFeatures
:
[
'
hit-test
'
]
});
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
'
);
...
...
@@ -69,8 +70,6 @@
session
.
requestAnimationFrame
(
onXRFrame
);
// AR-Rendering
function
onXRFrame
(
time
,
frame
)
{
session
.
requestAnimationFrame
(
onXRFrame
);
...
...
@@ -99,6 +98,18 @@
}
}
// Modell platzieren
function
placeModel
()
{
if
(
reticle
.
visible
)
{
const
model
=
models
[
selectedModel
];
if
(
model
)
{
const
clonedModel
=
model
.
clone
();
clonedModel
.
position
.
set
(
reticle
.
position
.
x
,
reticle
.
position
.
y
,
reticle
.
position
.
z
);
scene
.
add
(
clonedModel
);
}
}
}
// AR starten
if
(
navigator
.
xr
)
{
const
startButton
=
document
.
createElement
(
'
button
'
);
...
...
@@ -109,6 +120,9 @@
startButton
.
remove
();
activateXR
();
};
// Touch- oder Klick-Event, um das Modell zu platzieren
document
.
body
.
addEventListener
(
'
click
'
,
placeModel
);
}
else
{
alert
(
'
WebXR wird nicht unterstützt.
'
);
}
...
...
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