2020-04-01 19:29:00 -04:00
So you want to host your own version of the webclient? It's pretty easy to do, you need 3 files:
2020-07-08 04:26:16 -04:00
1) A web page to initialise the .js and display the game
2) The game .js file
2020-04-01 19:29:00 -04:00
3) The default texture pack
### Example setup
For example, let's assume our site is setup like this:
* `example.com/play.html`
* `example.com/static/classisphere.js`
* `example.com/static/default.zip`
For simplicitly,
2020-08-20 04:56:05 -04:00
1) Download `cs.classicube.net/c_client/latest/ClassiCube.js` , then upload it to `static/classisphere.js` on the webserver
2020-07-08 04:26:16 -04:00
2) Download `classicube.net/static/default.zip` , then upload it to `static/default.zip` on the webserver
2020-04-01 19:29:00 -04:00
2020-04-02 05:17:52 -04:00
The play.html page is the trickiest part, because how to implement this is website-specific. (depends on how your website is styled, what webserver you use, what programming language is used to generate the html, etc)
2020-04-01 19:29:00 -04:00
2020-04-02 04:57:36 -04:00
#### Embedding the game in play.html
2020-04-01 19:29:00 -04:00
2020-04-02 04:57:36 -04:00
You are required to have this HTML code somewhere in the page:
```HTML
2020-08-22 02:18:39 -04:00
<!-- the canvas *must not* have any border or padding, or mouse coords will be wrong -->
2020-08-22 09:44:03 -04:00
< canvas id = "canvas" style = "display:block; border:0; padding:0; background-color: black;"
oncontextmenu="event.preventDefault()" tabindex=-1>< / canvas >
2020-04-02 04:57:36 -04:00
< span id = "logmsg" > < / span >
< script type = 'text/javascript' >
var Module = {
2022-09-12 06:23:31 -04:00
preRun: [],
2020-04-02 04:57:36 -04:00
postRun: [],
arguments: [ {username}, {mppass}, {server ip}, {server port} ],
print: function(text) {
if (arguments.length > 1) text = Array.prototype.slice.call(arguments).join(' ');
console.log(text);
},
printErr: function(text) {
if (arguments.length > 1) text = Array.prototype.slice.call(arguments).join(' ');
console.error(text);
},
2020-08-22 02:18:39 -04:00
canvas: (function() { return document.getElementById('canvas'); })(),
2020-04-02 04:57:36 -04:00
setStatus: function(text) {
console.log(text);
document.getElementById('logmsg').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.');
}
};
Module.setStatus('Downloading...');
2020-08-22 02:18:39 -04:00
window.onerror = function(msg) {
2020-04-02 04:57:36 -04:00
// TODO: do not warn on ok events like simulating an infinite loop or exitStatus
2020-08-22 02:18:39 -04:00
Module.setStatus('Exception thrown, see JavaScript console (' + msg + ')');
2020-04-02 04:57:36 -04:00
Module.setStatus = function(text) {
if (text) Module.printErr('[post-exception status] ' + text);
};
};
< / script >
< script async type = "text/javascript" src = "/static/classisphere.js" > < / script >
```
2020-08-22 09:44:03 -04:00
**To start in singleplayer instead, just use `arguments: [ {username} ],` instead**
2020-04-02 04:57:36 -04:00
##### Variables
* {username} - the player's username
* {mppass} - if server verifies names, [mppass ](https://wiki.vg/Classic_Protocol#User_Authentication ). Otherwise leave as `''` .
* {server ip} - the IP address of the server to connect to
* {server port} - the port on the server to connect on (usually `'25565'` )
2020-04-02 05:17:52 -04:00
### Complete example
2020-04-02 04:57:36 -04:00
2021-11-10 01:39:20 -05:00
The links below show how to integrate the webclient into a simple website
2020-04-03 23:50:14 -04:00
* [Flask (python webserver) ](hosting-flask.md )
2020-11-03 06:43:36 -05:00
### iOS / Android support
The webclient is compatible with Android / iOS devices and will show a touch based UI to these devices.
However, due to the limited screen size available on such devices, you should consider serving a webpage consisting of just the `<canvas>` to these devices - no header, footer or anything else.
Additionally, you will likely want to ensure zooming is disabled, viewport width is same as the device's width, and that 'add to device homescreen' is fully supported. You can accomplish that by adding these three HTML tags to the page:
```HTML
< meta name = "apple-mobile-web-app-capable" content = "yes" >
< meta name = "mobile-web-app-capable" content = "yes" >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" >
```