Basic Properties

The key properties common to all Wijmo gauge classes are: min, max, and value.

The showText property is used to show the min/max/value properties as text on the gauge.

Wijmo gauges can also be used as input controls. If you set their isReadOnly property to false, users will be able to change the value using the mouse, keyboard, or touch.

app.js
index.html
styles.css
Copy to CodeMine
import 'bootstrap.css'; import '@mescius/wijmo.styles/wijmo.css'; import './styles.css'; import * as input from '@mescius/wijmo.input'; import * as gauge from '@mescius/wijmo.gauge'; // document.readyState === 'complete' ? init() : window.onload = init; // function init() { // create gauges let theRadialGauge = new gauge.RadialGauge('#theRadialGauge', { min: 0, max: 100, value: 75, showText: 'None', valueChanged: (s, e) => { valueCtl.value = s.value; } }); let theLinearGauge = new gauge.LinearGauge('#theLinearGauge', { min: 0, max: 100, value: 75, showText: 'None', valueChanged: (s, e) => { valueCtl.value = s.value; } }); let theBulletGraph = new gauge.BulletGraph('#theBulletGraph', { min: 0, max: 100, value: 75, target: 60, bad: 50, good: 70, showText: 'None', valueChanged: (s, e) => { valueCtl.value = s.value; } }); function getGaugeProp(prop) { return theRadialGauge[prop]; } function setGaugeProp(prop, value) { theRadialGauge[prop] = value; theLinearGauge[prop] = value; theBulletGraph[prop] = value; } // // create controls to change gauge properties let minCtl = new input.InputNumber('#min', { step: 10, value: getGaugeProp('min'), valueChanged: (s, e) => { setGaugeProp('min', s.value); } }); let maxCtl = new input.InputNumber('#max', { step: 10, value: getGaugeProp('max'), valueChanged: (s, e) => { setGaugeProp('max', s.value); } }); let valueCtl = new input.InputNumber('#value', { step: 10, value: getGaugeProp('value'), valueChanged: (s, e) => { setGaugeProp('value', s.value); } }); let showTextCtl = new input.ComboBox('#showText', { itemsSource: 'None,Value,MinMax,All'.split(','), text: getGaugeProp('showText'), textChanged: (s, e) => { setGaugeProp('showText', s.text); } }); document.getElementById('isReadOnly').addEventListener('click', (e) => { setGaugeProp('isReadOnly', e.target.checked); }); let stepCtl = new input.InputNumber('#step', { min: 1, step: 1, value: getGaugeProp('step'), valueChanged: (s, e) => { setGaugeProp('step', s.value); } }); document.getElementById('isAnimated').addEventListener('click', (e) => { setGaugeProp('isAnimated', e.target.checked); }); }
import 'bootstrap.css'; import '@mescius/wijmo.styles/wijmo.css'; import './styles.css'; import * as input from '@mescius/wijmo.input'; import * as gauge from '@mescius/wijmo.gauge'; // document.readyState === 'complete' ? init() : window.onload = init; // function init() { // create gauges let theRadialGauge = new gauge.RadialGauge('#theRadialGauge', { min: 0, max: 100, value: 75, showText: 'None', valueChanged: (s, e) => { valueCtl.value = s.value; } }); let theLinearGauge = new gauge.LinearGauge('#theLinearGauge', { min: 0, max: 100, value: 75, showText: 'None', valueChanged: (s, e) => { valueCtl.value = s.value; } }); let theBulletGraph = new gauge.BulletGraph('#theBulletGraph', { min: 0, max: 100, value: 75, target: 60, bad: 50, good: 70, showText: 'None', valueChanged: (s, e) => { valueCtl.value = s.value; } }); function getGaugeProp(prop) { return theRadialGauge[prop]; } function setGaugeProp(prop, value) { theRadialGauge[prop] = value; theLinearGauge[prop] = value; theBulletGraph[prop] = value; } // // create controls to change gauge properties let minCtl = new input.InputNumber('#min', { step: 10, value: getGaugeProp('min'), valueChanged: (s, e) => { setGaugeProp('min', s.value); } }); let maxCtl = new input.InputNumber('#max', { step: 10, value: getGaugeProp('max'), valueChanged: (s, e) => { setGaugeProp('max', s.value); } }); let valueCtl = new input.InputNumber('#value', { step: 10, value: getGaugeProp('value'), valueChanged: (s, e) => { setGaugeProp('value', s.value); } }); let showTextCtl = new input.ComboBox('#showText', { itemsSource: 'None,Value,MinMax,All'.split(','), text: getGaugeProp('showText'), textChanged: (s, e) => { setGaugeProp('showText', s.text); } }); document.getElementById('isReadOnly').addEventListener('click', (e) => { setGaugeProp('isReadOnly', e.target.checked); }); let stepCtl = new input.InputNumber('#step', { min: 1, step: 1, value: getGaugeProp('step'), valueChanged: (s, e) => { setGaugeProp('step', s.value); } }); document.getElementById('isAnimated').addEventListener('click', (e) => { setGaugeProp('isAnimated', e.target.checked); }); }
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>Gauge Basics</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- SystemJS --> <script src="https://cdnjs.cloudflare.com/ajax/libs/systemjs/0.21.5/system.src.js" integrity="sha512-skZbMyvYdNoZfLmiGn5ii6KmklM82rYX2uWctBhzaXPxJgiv4XBwJnFGr5k8s+6tE1pcR1nuTKghozJHyzMcoA==" crossorigin="anonymous"></script> <script src="systemjs.config.js"></script> <script> System.import('./src/app'); </script> </head> <body> <div class="container-fluid"> <div class="row"> <div class="col-xs-6"> <div class="form-group"> <label for="min">min:</label> <div id="min"></div> </div> <div class="form-group"> <label for="max">max:</label> <div id="max"></div> </div> <div class="form-group"> <label for="value">value:</label> <div id="value"></div> </div> <div class="form-group"> <label for="showText">showText:</label> <div id="showText"></div> </div> <div class="form-check"> <label for="isReadOnly">isReadOnly:</label> <input id="isReadOnly" type="checkbox" checked="checked" class="form-check-input"> </div> <div class="form-group"> <label for="step">step:</label> <div id="step"></div> </div> <div class="form-check"> <label for="isAnimated">isAnimated:</label> <input id="isAnimated" type="checkbox" checked="checked" class="form-check-input"> </div> </div> <div class="col-xs-6"> <div id="theRadialGauge"></div> <div id="theLinearGauge"></div> <div id="theBulletGraph"></div> </div> </div> </div> </body> </html>
label { width: 150px; text-align: right; margin-right: 3px; } .wj-inputnumber, .wj-combobox { width: 140px; } .wj-gauge { margin: 20px auto; } .wj-radialgauge { height: 100px; } body { margin-bottom: 24pt; }
(function (global) { System.config({ transpiler: 'plugin-babel', babelOptions: { es2015: true }, meta: { '*.css': { loader: 'css' } }, paths: { // paths serve as alias 'npm:': 'node_modules/' }, // map tells the System loader where to look for things map: { 'jszip': 'npm:jszip/dist/jszip.js', '@mescius/wijmo': 'npm:@mescius/wijmo/index.js', '@mescius/wijmo.input': 'npm:@mescius/wijmo.input/index.js', '@mescius/wijmo.styles': 'npm:@mescius/wijmo.styles', '@mescius/wijmo.cultures': 'npm:@mescius/wijmo.cultures', '@mescius/wijmo.chart': 'npm:@mescius/wijmo.chart/index.js', '@mescius/wijmo.chart.analytics': 'npm:@mescius/wijmo.chart.analytics/index.js', '@mescius/wijmo.chart.animation': 'npm:@mescius/wijmo.chart.animation/index.js', '@mescius/wijmo.chart.annotation': 'npm:@mescius/wijmo.chart.annotation/index.js', '@mescius/wijmo.chart.finance': 'npm:@mescius/wijmo.chart.finance/index.js', '@mescius/wijmo.chart.finance.analytics': 'npm:@mescius/wijmo.chart.finance.analytics/index.js', '@mescius/wijmo.chart.hierarchical': 'npm:@mescius/wijmo.chart.hierarchical/index.js', '@mescius/wijmo.chart.interaction': 'npm:@mescius/wijmo.chart.interaction/index.js', '@mescius/wijmo.chart.radar': 'npm:@mescius/wijmo.chart.radar/index.js', '@mescius/wijmo.chart.render': 'npm:@mescius/wijmo.chart.render/index.js', '@mescius/wijmo.chart.webgl': 'npm:@mescius/wijmo.chart.webgl/index.js', '@mescius/wijmo.chart.map': 'npm:@mescius/wijmo.chart.map/index.js', '@mescius/wijmo.gauge': 'npm:@mescius/wijmo.gauge/index.js', '@mescius/wijmo.grid': 'npm:@mescius/wijmo.grid/index.js', '@mescius/wijmo.grid.detail': 'npm:@mescius/wijmo.grid.detail/index.js', '@mescius/wijmo.grid.filter': 'npm:@mescius/wijmo.grid.filter/index.js', '@mescius/wijmo.grid.search': 'npm:@mescius/wijmo.grid.search/index.js', '@mescius/wijmo.grid.style': 'npm:@mescius/wijmo.grid.style/index.js', '@mescius/wijmo.grid.grouppanel': 'npm:@mescius/wijmo.grid.grouppanel/index.js', '@mescius/wijmo.grid.multirow': 'npm:@mescius/wijmo.grid.multirow/index.js', '@mescius/wijmo.grid.transposed': 'npm:@mescius/wijmo.grid.transposed/index.js', '@mescius/wijmo.grid.transposedmultirow': 'npm:@mescius/wijmo.grid.transposedmultirow/index.js', '@mescius/wijmo.grid.pdf': 'npm:@mescius/wijmo.grid.pdf/index.js', '@mescius/wijmo.grid.sheet': 'npm:@mescius/wijmo.grid.sheet/index.js', '@mescius/wijmo.grid.xlsx': 'npm:@mescius/wijmo.grid.xlsx/index.js', '@mescius/wijmo.grid.selector': 'npm:@mescius/wijmo.grid.selector/index.js', '@mescius/wijmo.grid.cellmaker': 'npm:@mescius/wijmo.grid.cellmaker/index.js', '@mescius/wijmo.nav': 'npm:@mescius/wijmo.nav/index.js', '@mescius/wijmo.odata': 'npm:@mescius/wijmo.odata/index.js', '@mescius/wijmo.olap': 'npm:@mescius/wijmo.olap/index.js', '@mescius/wijmo.rest': 'npm:@mescius/wijmo.rest/index.js', '@mescius/wijmo.pdf': 'npm:@mescius/wijmo.pdf/index.js', '@mescius/wijmo.pdf.security': 'npm:@mescius/wijmo.pdf.security/index.js', '@mescius/wijmo.viewer': 'npm:@mescius/wijmo.viewer/index.js', '@mescius/wijmo.xlsx': 'npm:@mescius/wijmo.xlsx/index.js', '@mescius/wijmo.undo': 'npm:@mescius/wijmo.undo/index.js', '@mescius/wijmo.interop.grid': 'npm:@mescius/wijmo.interop.grid/index.js', '@mescius/wijmo.touch': 'npm:@mescius/wijmo.touch/index.js', '@mescius/wijmo.cloud': 'npm:@mescius/wijmo.cloud/index.js', '@mescius/wijmo.barcode': 'npm:@mescius/wijmo.barcode/index.js', '@mescius/wijmo.barcode.common': 'npm:@mescius/wijmo.barcode.common/index.js', '@mescius/wijmo.barcode.composite': 'npm:@mescius/wijmo.barcode.composite/index.js', '@mescius/wijmo.barcode.specialized': 'npm:@mescius/wijmo.barcode.specialized/index.js', 'jszip': 'npm:jszip/dist/jszip.js', 'bootstrap.css': 'npm:bootstrap/dist/css/bootstrap.min.css', 'css': 'npm:systemjs-plugin-css/css.js', 'plugin-babel': 'npm:systemjs-plugin-babel/plugin-babel.js', 'systemjs-babel-build':'npm:systemjs-plugin-babel/systemjs-babel-browser.js' }, // packages tells the System loader how to load when no filename and/or no extension packages: { src: { defaultExtension: 'js' }, "node_modules": { defaultExtension: 'js' }, } }); })(this);