mirror of
https://github.com/sehugg/8bitworkshop.git
synced 2025-01-02 23:30:21 +00:00
can't resume before ROM build; added verilog to demo.html
This commit is contained in:
parent
d5154a649a
commit
8e1ddfe1ea
78
demo.html
78
demo.html
@ -92,66 +92,24 @@ if (window.location.host.endsWith('8bitworkshop.com')) {
|
|||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
<p>
|
<h2><a href="redir.html?platform=verilog">Hardware Design</a></h2>
|
||||||
We're always adding new things here, so subscribe to our mailing list for updates!
|
|
||||||
</p>
|
|
||||||
<style> .gumroad-follow-form-embed { zoom: 1; } .gumroad-follow-form-embed:before, .gumroad-follow-form-embed:after { display: table; line-height: 0; content: ""; } .gumroad-follow-form-embed:after { clear: both; } .gumroad-follow-form-embed * { margin: 0; border: 0; padding: 0; outline: 0; box-sizing: border-box !important; float: left !important; } .gumroad-follow-form-embed input { border-radius: 4px; border-top-right-radius: 0; border-bottom-right-radius: 0; font-family: -apple-system, ".SFNSDisplay-Regular", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; line-height: 20px; background: #fff; border: 1px solid #ddd; border-right: 0; color: #aaa; padding: 10px; box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.02); background-position: top right; background-repeat: no-repeat; text-rendering: optimizeLegibility; font-smoothing: antialiased; -webkit-appearance: none; -moz-appearance: caret; width: 65% !important; height: 40px !important; } .gumroad-follow-form-embed button { border-radius: 4px; border-top-left-radius: 0; border-bottom-left-radius: 0; box-shadow: 0 1px 1px rgba(0, 0, 0, 0.12); -webkit-transition: all .05s ease-in-out; transition: all .05s ease-in-out; display: inline-block; padding: 11px 15px 12px; cursor: pointer; color: #fff; font-size: 15px; line-height: 100%; font-family: -apple-system, ".SFNSDisplay-Regular", "Helvetica Neue", Helvetica, Arial, sans-serif; background: #36a9ae; border: 1px solid #31989d; filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#5ccfd4, endColorstr=#329ca1, GradientType=0)"; background: -webkit-linear-gradient(#5ccfd4, #329ca1); background: linear-gradient(to bottom, #5ccfd4, #329ca1); height: 40px !important; width: 35% !important; } </style> <form action="https://gumroad.com/follow_from_embed_form" class="form gumroad-follow-form-embed" method="post"> <input name="seller_id" type="hidden" value="1507538753888"> <input name="email" placeholder="Your email address" type="email"> <button data-custom-highlight-color="" type="submit">Subscribe</button> </form>
|
|
||||||
<p></p>
|
|
||||||
<!-- Begin MailChimp Signup Form -->
|
|
||||||
<!--
|
|
||||||
<link href="//cdn-images.mailchimp.com/embedcode/classic-10_7.css" rel="stylesheet" type="text/css">
|
|
||||||
<style type="text/css">
|
|
||||||
#mc_embed_signup{background:#fff; clear:left; font:14px Helvetica,Arial,sans-serif; }
|
|
||||||
/* Add your own MailChimp form style overrides in your site stylesheet or in this style block.
|
|
||||||
We recommend moving this block and the preceding CSS link to the HEAD of your HTML file. */
|
|
||||||
</style>
|
|
||||||
<div id="mc_embed_signup">
|
|
||||||
<form action="https://8bitworkshop.us19.list-manage.com/subscribe/post?u=819ee5274c8c9c1afe2005023&id=75411a270f" method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate" target="_blank" novalidate>
|
|
||||||
<div id="mc_embed_signup_scroll">
|
|
||||||
<h2>We're always adding new things here, so subscribe to our mailing list for updates!</h2>
|
|
||||||
<div class="indicates-required"><span class="asterisk">*</span> indicates required</div>
|
|
||||||
<div class="mc-field-group">
|
|
||||||
<label for="mce-EMAIL">Email Address <span class="asterisk">*</span>
|
|
||||||
</label>
|
|
||||||
<input type="email" value="" name="EMAIL" class="required email" id="mce-EMAIL">
|
|
||||||
</div>
|
|
||||||
<div class="mc-field-group">
|
|
||||||
<label for="mce-FNAME">First Name (optional)</label>
|
|
||||||
<input type="text" value="" name="FNAME" class="" id="mce-FNAME">
|
|
||||||
</div>
|
|
||||||
<div class="mc-field-group">
|
|
||||||
<label for="mce-LNAME">Last Name (optional)</label>
|
|
||||||
<input type="text" value="" name="LNAME" class="" id="mce-LNAME">
|
|
||||||
</div>
|
|
||||||
<div id="mce-responses" class="clear">
|
|
||||||
<div class="response" id="mce-error-response" style="display:none"></div>
|
|
||||||
<div class="response" id="mce-success-response" style="display:none"></div>
|
|
||||||
</div>
|
|
||||||
<div style="position: absolute; left: -5000px;" aria-hidden="true"><input type="text" name="b_819ee5274c8c9c1afe2005023_75411a270f" tabindex="-1" value=""></div>
|
|
||||||
<div class="clear"><input type="submit" value="Subscribe" name="subscribe" id="mc-embedded-subscribe" class="button"></div>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
<script type='text/javascript' src='//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script><script type='text/javascript'>(function($) {window.fnames = new Array(); window.ftypes = new Array();fnames[0]='EMAIL';ftypes[0]='email';fnames[1]='FNAME';ftypes[1]='text';fnames[2]='LNAME';ftypes[2]='text';fnames[3]='ADDRESS';ftypes[3]='address';fnames[4]='PHONE';ftypes[4]='phone';}(jQuery));var $mcj = jQuery.noConflict(true);</script>
|
|
||||||
-->
|
|
||||||
<!--End mc_embed_signup-->
|
|
||||||
</div>
|
|
||||||
<!--
|
|
||||||
<div class="col-md-4">
|
|
||||||
<h2>Hardware Design</h2>
|
|
||||||
<p>
|
<p>
|
||||||
Software not enough for you?
|
Software not enough for you?
|
||||||
Use our
|
Use our
|
||||||
<a href="redir.html?platform=verilog">Verilog</a>
|
<a href="redir.html?platform=verilog">Verilog</a>
|
||||||
compiler to design a 8-bit game platform from scratch.
|
compiler to design a 8-bit game platform from scratch.
|
||||||
We'll run your design in real time in the browser, showing the output on a simulated CRT.
|
We'll run your design in real time in the browser, displaying the output on a simulated CRT.
|
||||||
Plenty of examples are available to teach logic programming.
|
Plenty of examples are included to teach logic programming.
|
||||||
|
The book even shows you how to synthesize your code to the
|
||||||
|
<a href="<a target="_blank" href="https://www.amazon.com/gp/product/B00R3QU9K0/ref=as_li_tl?ie=UTF8&camp=1789&creative=9325&creativeASIN=B00R3QU9K0&linkCode=as2&tag=pzp-20&linkId=5e51c89e29bec87dfb4d81f89fdec3fe">Lattice iCE Stick FPGA</a><img src="//ir-na.amazon-adsystem.com/e/ir?t=pzp-20&l=am2&o=1&a=B00R3QU9K0" width="1" height="1" border="0" alt="" style="border:none !important; margin:0px !important;" />
|
||||||
|
and connect to a legacy CRT or TV.
|
||||||
</p>
|
</p>
|
||||||
|
<img class="img-responsive" src="images/fpga.jpg">
|
||||||
</div>
|
</div>
|
||||||
-->
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<h1 class="text-center">Learn More With a Book!</h1>
|
<h1 class="text-center">Learn More With a Book!</h1>
|
||||||
|
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-2">
|
<div class="col-md-2">
|
||||||
@ -179,6 +137,26 @@ We're always adding new things here, so subscribe to our mailing list for update
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-2">
|
||||||
|
<a target="_blank" href="https://www.amazon.com/gp/product/1541021304/ref=as_li_tl?ie=UTF8&camp=1789&creative=9325&creativeASIN=1541021304&linkCode=as2&tag=pzp-20&linkId=c149f6365c0a676065eb6d7c5f8dd6ae" onclick="ga('send', 'event', 'books', 'click', 'verilog');">
|
||||||
|
<img class="img-responsive" border="0" src="./images/book_verilog.jpg" ></a>
|
||||||
|
<img src="//ir-na.amazon-adsystem.com/e/ir?t=pzp-20&l=am2&o=1&a=1541021304" />
|
||||||
|
</div>
|
||||||
|
<div class="col-md-4">
|
||||||
|
<a target="_blank" href="https://www.amazon.com/gp/product/1541021304/ref=as_li_tl?ie=UTF8&camp=1789&creative=9325&creativeASIN=1541021304&linkCode=as2&tag=pzp-20&linkId=c149f6365c0a676065eb6d7c5f8dd6ae" onclick="ga('send', 'event', 'books', 'click', 'verilog');">
|
||||||
|
<h3>Designing Video Game Hardware in Verilog</h3>
|
||||||
|
</a>
|
||||||
|
<p>
|
||||||
|
This book attempts to capture the spirit of the ''Bronze Age'' of video games, when video games were designed as circuits, not as software.
|
||||||
|
We'll delve into these circuits as they morph from Pong into programmable personal computers and game consoles. Instead of wire-wrap and breadboards, we'll use modern tools to approximate these old designs in a simulated environment from the comfort of our keyboards.
|
||||||
|
At the end of this adventure, you should be well-equipped to begin exploring the world of FPGAs, and maybe even design your own game console. You'll use the 8bitworkshop.com IDE to write Verilog programs that represent digital circuits, and see your code run instantly in the browser.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<h1 class="text-center">Supported Platforms</h1>
|
<h1 class="text-center">Supported Platforms</h1>
|
||||||
<div class="container">
|
<div class="container">
|
||||||
|
@ -146,3 +146,6 @@ worker result:
|
|||||||
}
|
}
|
||||||
|
|
||||||
add file to errors
|
add file to errors
|
||||||
|
|
||||||
|
http://www.playvectrex.com/designit/chrissalo/vectordisplay.htm
|
||||||
|
http://oldies.malban.de/secondvectrex/index.htm
|
||||||
|
BIN
images/book_verilog.jpg
Normal file
BIN
images/book_verilog.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 49 KiB |
BIN
images/fpga.jpg
Normal file
BIN
images/fpga.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 100 KiB |
@ -540,8 +540,8 @@ function setCompileOutput(data: WorkerResult) {
|
|||||||
clearBreakpoint(); // so we can replace memory (TODO: change toolbar btn)
|
clearBreakpoint(); // so we can replace memory (TODO: change toolbar btn)
|
||||||
_resetRecording();
|
_resetRecording();
|
||||||
platform.loadROM(getCurrentPresetTitle(), rom);
|
platform.loadROM(getCurrentPresetTitle(), rom);
|
||||||
if (!userPaused) _resume();
|
|
||||||
current_output = rom;
|
current_output = rom;
|
||||||
|
if (!userPaused) _resume();
|
||||||
// TODO: reset profiler etc? (Tell views?)
|
// TODO: reset profiler etc? (Tell views?)
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.log(e);
|
console.log(e);
|
||||||
@ -625,7 +625,11 @@ function pause() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function _resume() {
|
function _resume() {
|
||||||
if (! platform.isRunning()) {
|
if (current_output == null) {
|
||||||
|
alert("Can't resume emulation until ROM is successfully built.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!platform.isRunning()) {
|
||||||
platform.resume();
|
platform.resume();
|
||||||
console.log("Resumed");
|
console.log("Resumed");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user