|
| 1 | +<!DOCTYPE html> |
| 2 | +<html lang="en"> |
| 3 | +<head> |
| 4 | + <meta charset="utf-8"> |
| 5 | + <title>JSDoc: Source: visualization/models/Button.js</title> |
| 6 | + |
| 7 | + <script src="scripts/prettify/prettify.js"> </script> |
| 8 | + <script src="scripts/prettify/lang-css.js"> </script> |
| 9 | + <!--[if lt IE 9]> |
| 10 | + <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script> |
| 11 | + <![endif]--> |
| 12 | + <link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css"> |
| 13 | + <link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css"> |
| 14 | +</head> |
| 15 | + |
| 16 | +<body> |
| 17 | + |
| 18 | +<div id="main"> |
| 19 | + |
| 20 | + <h1 class="page-title">Source: visualization/models/Button.js</h1> |
| 21 | + |
| 22 | + |
| 23 | + |
| 24 | + |
| 25 | + |
| 26 | + <section> |
| 27 | + <article> |
| 28 | + <pre class="prettyprint source"><code>/** |
| 29 | + * @author Russell Toris - [email protected] |
| 30 | + */ |
| 31 | + |
| 32 | +/** |
| 33 | + * A button renders a button with text to an internal canvas. The width will scale to fit the text. |
| 34 | + * |
| 35 | + * @constructor |
| 36 | + * @param options - possible keys include: |
| 37 | + * * text - the text to display on the button |
| 38 | + * * height - the height of the button |
| 39 | + */ |
| 40 | +MJPEGCANVAS.Button = function(options) { |
| 41 | + options = options || {}; |
| 42 | + this.text = options.text; |
| 43 | + this.height = options.height; |
| 44 | + |
| 45 | + // used to draw the text internally |
| 46 | + this.canvas = document.createElement('canvas'); |
| 47 | + this.redraw(); |
| 48 | +}; |
| 49 | + |
| 50 | +/** |
| 51 | + * Redraw the button to the internal canvas. |
| 52 | + */ |
| 53 | +MJPEGCANVAS.Button.prototype.redraw = function() { |
| 54 | + var context = this.canvas.getContext('2d'); |
| 55 | + |
| 56 | + // determine text size |
| 57 | + var buttonPadding = this.height * 0.33; |
| 58 | + context.font = (this.height - buttonPadding) + 'px Verdana'; |
| 59 | + this.width = context.measureText(this.text).width + buttonPadding * 2; |
| 60 | + this.canvas.width = this.width; |
| 61 | + this.canvas.height = this.height; |
| 62 | + |
| 63 | + // create the image |
| 64 | + var image = new Image(); |
| 65 | + // keep the base64 representation internally |
| 66 | + image.src = ''; |
| 67 | + |
| 68 | + // draw the button |
| 69 | + context.drawImage(image, 0, 0, this.width, this.height); |
| 70 | + |
| 71 | + // draw the text |
| 72 | + context.font = (this.height - buttonPadding) + 'px Verdana'; |
| 73 | + context.fillStyle = '#121212'; |
| 74 | + context.fillText(this.text, buttonPadding, this.height - buttonPadding); |
| 75 | +}; |
| 76 | +</code></pre> |
| 77 | + </article> |
| 78 | + </section> |
| 79 | + |
| 80 | + |
| 81 | + |
| 82 | + |
| 83 | +</div> |
| 84 | + |
| 85 | +<nav> |
| 86 | + <h2><a href="index.html">Index</a></h2><h3>Classes</h3><ul><li><a href="MJPEGCANVAS.Button.html">Button</a></li><li><a href="MJPEGCANVAS.ErrorIcon.html">ErrorIcon</a></li><li><a href="MJPEGCANVAS.MultiStreamViewer.html">MultiStreamViewer</a></li><li><a href="MJPEGCANVAS.Viewer.html">Viewer</a></li></ul><h3>Global</h3><ul><li><a href="global.html#MJPEGCANVAS">MJPEGCANVAS</a></li></ul> |
| 87 | +</nav> |
| 88 | + |
| 89 | +<br clear="both"> |
| 90 | + |
| 91 | +<footer> |
| 92 | + Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.2.0-dev</a> on Tue Mar 10 2015 09:06:06 GMT-0400 (EDT) |
| 93 | +</footer> |
| 94 | + |
| 95 | +<script> prettyPrint(); </script> |
| 96 | +</body> |
| 97 | +</html> |
0 commit comments