Merge branch 'master' into click-listener

This commit is contained in:
Felix Rieseberg 2018-08-23 15:56:49 -07:00 committed by GitHub
commit 1fbfca70b2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 95 additions and 16 deletions

View file

@ -1,7 +1,7 @@
{
"name": "windows95",
"productName": "windows95",
"version": "1.0.0",
"version": "1.1.0",
"description": "Windows 95, in an app. I'm sorry.",
"main": "src/index.js",
"scripts": {
@ -18,7 +18,10 @@
"forge": "./forge.config.js"
},
"standard": {
"globals": [ "V86Starter", "windows95" ],
"globals": [
"V86Starter",
"windows95"
],
"ignore": [
"/src/renderer/lib/*.js"
]

View file

@ -24,6 +24,17 @@
</div>
<div id="other-buttons">
<div class="btn" id="reset">Reset Machine & Delete State</div>
<div class="btn" id="floppy">Insert Floppy Disk</div>
<div class="btn" id="discard-state">Discard State & Boot From Scratch</div>
<input id="file-input" type='file'>
</div>
<div id="information">
<p id="floppy-path"></p>
<p>You can insert a floppy disk image with the ".img" format.</p>
<p>
Boot the machine from scratch if you've inserted a new floppy disk to
make sure that Windows can load it.
</p>
</div>
</div>
<div id="emulator" style="height: 100vh; width: 100vw">

View file

@ -1,6 +1,11 @@
const BUTTONS = document.querySelector('#buttons')
const $ = document.querySelector.bind(document)
const $$ = document.querySelectorAll.bind(document)
const BUTTONS = $('#buttons')
let cursorCaptured = false
let floppyFile = null
let bootFresh = false
const OPTIONS = {
win95: {
@ -21,15 +26,25 @@ async function main (id) {
},
vga_bios: {
url: './bios/vgabios.bin'
}
},
fda: {
buffer: floppyFile || undefined
},
boot_order: 0x132
}, OPTIONS[id])
// New v86 instance
window.emulator = new V86Starter(opts)
//high-dpi support
var scale = window.devicePixelRatio;
window.emulator.screen_adapter.set_scale(scale,scale);
// Restore state. We can't do this right away.
setTimeout(async () => {
await windows95.restoreState()
if (!bootFresh) {
await windows95.restoreState()
}
cursorCaptured = true
window.emulator.lock_mouse()
@ -37,17 +52,21 @@ async function main (id) {
}, 500)
}
function start (id) {
BUTTONS.remove()
document.body.className = ''
setupClickListener()
main(id)
}
function setupButtons () {
document.querySelectorAll('.btn-start').forEach((btn) => {
btn.addEventListener('click', () => {
BUTTONS.remove()
document.body.className = ''
main(btn.id)
setupClickListener()
})
// Start
$$('.btn-start').forEach((btn) => {
btn.addEventListener('click', () => start(btn.id))
})
document.querySelector('#reset').addEventListener('click', () => {
// Reset
$('#reset').addEventListener('click', () => {
if (window.emulator.stop) {
window.emulator.stop()
}
@ -58,7 +77,29 @@ function setupButtons () {
window.emulator.run()
}
document.querySelector('#reset').disabled = true
$('#reset').disabled = true
})
$('#discard-state').addEventListener('click', () => {
bootFresh = true
start('win95')
})
// Floppy
$('#floppy').addEventListener('click', () => {
$('#file-input').click()
})
// Floppy (Hidden Input)
$('#file-input').addEventListener('change', (event) => {
floppyFile = event.target.files && event.target.files.length > 0
? event.target.files[0]
: null
if (floppyFile) {
$('#floppy-path').innerHTML = `Inserted Floppy Disk: ${floppyFile.path}`
}
})
}

View file

@ -1,8 +1,32 @@
html, body {
margin: 0;
padding: 0;
}
body {
background: #000;
/* cursor: none; */
}
body.paused > #emulator {
display: none;
}
body.paused {
background: #008080;
font-family: Courier;
}
#floppy-path {
background: beige;
padding: 5px;
}
#information {
text-align: center;
position: absolute;
width: 100vw;
bottom: 50px;
font-size: 18px;
}
#emulator {
@ -13,7 +37,7 @@ html, body {
margin: auto;
}
body.paused > #emulator {
#file-input {
display: none;
}