Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
S
snake
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Armani2.Saintil@live.uwe.ac.uk
snake
Commits
f5da2453
Commit
f5da2453
authored
1 month ago
by
Armani2.Saintil@live.uwe.ac.uk
Browse files
Options
Downloads
Patches
Plain Diff
Upload New File
parent
c9a32b7c
No related branches found
No related tags found
No related merge requests found
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
shell.html
+301
-0
301 additions, 0 deletions
shell.html
with
301 additions
and
0 deletions
shell.html
0 → 100644
+
301
−
0
View file @
f5da2453
<!doctype html>
<html
lang=
"EN-us"
>
<head>
<meta
charset=
"utf-8"
>
<meta
http-equiv=
"Content-Type"
content=
"text/html; charset=utf-8"
>
<title>
POP Web Game
</title>
<meta
name=
"title"
content=
"POP Raylib Web game"
>
<meta
name=
"description"
content=
"POP game using raylib"
>
<meta
name=
"keywords"
content=
"raylib, programming, examples, html5, C, C++, library, learn, games, videogames"
>
<meta
name=
"viewport"
content=
"width=device-width"
>
<!-- Favicon -->
<link
rel=
"shortcut icon"
href=
"https://www.raylib.com/favicon.ico"
>
<style>
body
{
font-family
:
arial
;
margin
:
0
;
padding
:
none
;
}
#header
{
width
:
100%
;
height
:
80px
;
background-color
:
#888888
;
}
/* NOTE: raylib logo is embedded in the page as base64 png image */
#logo
{
width
:
64px
;
height
:
64px
;
float
:
left
;
position
:
relative
;
margin
:
10px
;
background-image
:
url('')
}
.emscripten
{
padding-right
:
0
;
margin-left
:
auto
;
margin-right
:
auto
;
display
:
block
;
}
div
.emscripten
{
text-align
:
center
;
}
div
.emscripten_border
{
border
:
1px
solid
black
;
}
/* NOTE: Canvas *must not* have any border or padding, or mouse coords will be wrong */
canvas
.emscripten
{
border
:
0px
none
;
background
:
black
;
width
:
512
;
height
:
512
;
}
.spinner
{
height
:
30px
;
width
:
30px
;
margin
:
0
;
margin-top
:
20px
;
margin-left
:
20px
;
display
:
inline-block
;
vertical-align
:
top
;
-webkit-animation
:
rotation
.8s
linear
infinite
;
-moz-animation
:
rotation
.8s
linear
infinite
;
-o-animation
:
rotation
.8s
linear
infinite
;
animation
:
rotation
0.8s
linear
infinite
;
border-left
:
5px
solid
black
;
border-right
:
5px
solid
black
;
border-bottom
:
5px
solid
black
;
border-top
:
5px
solid
red
;
border-radius
:
100%
;
background-color
:
rgb
(
245
,
245
,
245
);
}
@-webkit-keyframes
rotation
{
from
{
-webkit-transform
:
rotate
(
0deg
);}
to
{
-webkit-transform
:
rotate
(
360deg
);}
}
@-moz-keyframes
rotation
{
from
{
-moz-transform
:
rotate
(
0deg
);}
to
{
-moz-transform
:
rotate
(
360deg
);}
}
@-o-keyframes
rotation
{
from
{
-o-transform
:
rotate
(
0deg
);}
to
{
-o-transform
:
rotate
(
360deg
);}
}
@keyframes
rotation
{
from
{
transform
:
rotate
(
0deg
);}
to
{
transform
:
rotate
(
360deg
);}
}
#status
{
display
:
inline-block
;
vertical-align
:
top
;
margin-top
:
30px
;
margin-left
:
20px
;
font-weight
:
bold
;
color
:
rgb
(
40
,
40
,
40
);
}
#progress
{
height
:
0px
;
width
:
0px
;
}
#controls
{
display
:
inline-block
;
float
:
right
;
vertical-align
:
top
;
margin-top
:
15px
;
margin-right
:
20px
;
}
#output
{
width
:
100%
;
height
:
140px
;
margin
:
0
auto
;
margin-top
:
10px
;
display
:
block
;
background-color
:
black
;
color
:
rgb
(
37
,
174
,
38
);
font-family
:
'Lucida Console'
,
Monaco
,
monospace
;
outline
:
none
;
}
input
[
type
=
button
]
{
background-color
:
lightgray
;
border
:
4px
solid
darkgray
;
color
:
black
;
text-decoration
:
none
;
cursor
:
pointer
;
width
:
140px
;
height
:
50px
;
margin-left
:
10px
;
}
input
[
type
=
button
]
:hover
{
background-color
:
#f5f5f5
ff
;
border-color
:
black
;
}
</style>
</head>
<body>
<div
id=
"header"
>
<a
id=
"logo"
href=
"https://www.raylib.com"
></a>
<div
class=
"spinner"
id=
'spinner'
></div>
<div
class=
"emscripten"
id=
"status"
>
Downloading...
</div>
<span
id=
'controls'
>
<span><input
type=
"button"
value=
"📜 SOURCE CODE"
onclick=
"location.href='https://github.com/raysan5/raylib';"
/></span>
<span><input
type=
"button"
value=
"🖵 FULLSCREEN"
onclick=
"Module.requestFullscreen(false, false)"
></span>
<span><input
type=
"button"
id=
"btn-audio"
value=
"🔇 MUTE"
onclick=
"toggleAudio()"
></span>
</span>
<div
class=
"emscripten"
>
<progress
value=
"0"
max=
"100"
id=
"progress"
hidden=
1
></progress>
</div>
</div>
<div
class=
"emscripten_border"
>
<canvas
class=
"emscripten"
id=
"canvas"
oncontextmenu=
"event.preventDefault()"
tabindex=
-1
></canvas>
</div>
<textarea
id=
"output"
rows=
"8"
></textarea>
<script
type=
'text/javascript'
src=
"https://cdn.jsdelivr.net/gh/eligrey/FileSaver.js/dist/FileSaver.min.js"
>
</script>
<script
type=
'text/javascript'
>
function
saveFileFromMEMFSToDisk
(
memoryFSname
,
localFSname
)
// This can be called by C/C++ code
{
var
isSafari
=
false
;
// Not supported, navigator.userAgent access is being restricted
//var isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);
var
data
=
FS
.
readFile
(
memoryFSname
);
var
blob
;
if
(
isSafari
)
blob
=
new
Blob
([
data
.
buffer
],
{
type
:
"
application/octet-stream
"
});
else
blob
=
new
Blob
([
data
.
buffer
],
{
type
:
"
application/octet-binary
"
});
// NOTE: SaveAsDialog is a browser setting. For example, in Google Chrome,
// in Settings/Advanced/Downloads section you have a setting:
// 'Ask where to save each file before downloading' - which you can set true/false.
// If you enable this setting it would always ask you and bring the SaveAsDialog
saveAs
(
blob
,
localFSname
);
}
</script>
<script
type=
'text/javascript'
>
var
statusElement
=
document
.
querySelector
(
'
#status
'
);
var
progressElement
=
document
.
querySelector
(
'
#progress
'
);
var
spinnerElement
=
document
.
querySelector
(
'
#spinner
'
);
var
Module
=
{
preRun
:
[],
postRun
:
[],
print
:
(
function
()
{
var
element
=
document
.
querySelector
(
'
#output
'
);
if
(
element
)
element
.
value
=
''
;
// Clear browser cache
return
function
(
text
)
{
if
(
arguments
.
length
>
1
)
text
=
Array
.
prototype
.
slice
.
call
(
arguments
).
join
(
'
'
);
// These replacements are necessary if you render to raw HTML
//text = text.replace(/&/g, "&");
//text = text.replace(/
<
/g, "<"
)
;
//text = text.replace(/>/g, ">");
//text = text.replace('\n', '
<
br
>
'
,
'
g
'
);
console.log(text);
if (element) {
element.value += text + "
\n
";
element.scrollTop = element.scrollHeight; // focus on bottom
}
};
})(),
printErr: function(text) {
if (arguments.length > 1) text = Array.prototype.slice.call(arguments).join(
'
'
);
console.error(text);
},
canvas: (function() {
var canvas = document.querySelector(
'
#canvas
'
);
// As a default initial behavior, pop up an alert when webgl context is lost.
// To make your application robust, you may want to override this behavior before shipping!
// See http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.15.2
canvas.addEventListener("webglcontextlost", function(e) { alert(
'
WebGL
context
lost
.
You
will
need
to
reload
the
page
.
'
); e.preventDefault(); }, false);
return canvas;
})(),
setStatus: function(text) {
if (!Module.setStatus.last) Module.setStatus.last = { time: Date.now(), text:
''
};
if (text === Module.setStatus.last.text) return;
var m = text.match(/([^(]+)
\
((
\
d+(
\
.
\
d+)?)
\
/(
\
d+)
\
)/);
var now = Date.now();
if (m && now - Module.setStatus.last.time < 30) return; // If this is a progress update, skip it if too soon
Module.setStatus.last.time = now;
Module.setStatus.last.text = text;
if (m) {
text = m[1];
progressElement.value = parseInt(m[2])*100;
progressElement.max = parseInt(m[4])*100;
progressElement.hidden = true;
spinnerElement.hidden = false;
} else {
progressElement.value = null;
progressElement.max = null;
progressElement.hidden = true;
if (!text) spinnerElement.style.display =
'
none
'
;
}
statusElement.innerHTML = text;
},
totalDependencies: 0,
monitorRunDependencies: function(left) {
this.totalDependencies = Math.max(this.totalDependencies, left);
Module.setStatus(left ?
'
Preparing
...
(
'
+ (this.totalDependencies-left) +
'
/
'
+ this.totalDependencies +
'
)
'
:
'
All
downloads
complete
.
'
);
},
//noInitialRun: true
};
Module.setStatus(
'
Downloading
...
'
);
window.onerror = function() {
Module.setStatus(
'
Exception
thrown
,
see
JavaScript
console
'
);
spinnerElement.style.display =
'
none
'
;
Module.setStatus = function(text) { if (text) Module.printErr(
'
[
post
-
exception
status
]
'
+ text); };
};
</script>
<!-- REF: https://developers.google.com/web/updates/2018/11/web-audio-autoplay -->
<script
type=
'text/javascript'
>
var
audioBtn
=
document
.
querySelector
(
'
#btn-audio
'
);
// An array of all contexts to resume on the page
const
audioContexList
=
[];
(
function
()
{
// A proxy object to intercept AudioContexts and
// add them to the array for tracking and resuming later
self
.
AudioContext
=
new
Proxy
(
self
.
AudioContext
,
{
construct
(
target
,
args
)
{
const
result
=
new
target
(...
args
);
audioContexList
.
push
(
result
);
if
(
result
.
state
==
"
suspended
"
)
audioBtn
.
value
=
"
🔈 RESUME
"
;
return
result
;
}
});
})();
function
toggleAudio
()
{
var
resumed
=
false
;
audioContexList
.
forEach
(
ctx
=>
{
if
(
ctx
.
state
==
"
suspended
"
)
{
ctx
.
resume
();
resumed
=
true
;
}
else
if
(
ctx
.
state
==
"
running
"
)
ctx
.
suspend
();
});
if
(
resumed
)
audioBtn
.
value
=
"
🔇 MUTE
"
;
else
audioBtn
.
value
=
"
🔈 RESUME
"
;
}
</script>
{{{ SCRIPT }}}
</body>
</html>
\ No newline at end of file
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
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!
Save comment
Cancel
Please
register
or
sign in
to comment