goog.require('ol.RendererHint'); goog.require('ol.control.Attribution'); goog.require('ol.createMap'); goog.require('ol.interaction.Keyboard'); goog.require('ol.layer.MapQuestOpenAerial'); var layer = new ol.layer.MapQuestOpenAerial(); var layers = new ol.Collection(); layers.push(layer); var domMap = ol.createMap( document.getElementById('domMap'), {'layers': layers}, ol.RendererHint.DOM); domMap.setCenter(new ol.Coordinate(0, 0)); domMap.setResolution(layer.getStore().getResolutions()[0]); var webglMap = ol.createMap( document.getElementById('webglMap'), {}, ol.RendererHint.WEBGL); if (!goog.isNull(webglMap)) { webglMap.bindTo('center', domMap); webglMap.bindTo('layers', domMap); webglMap.bindTo('resolution', domMap); webglMap.bindTo('rotation', domMap); } var attributionControl = new ol.control.Attribution(domMap); document.getElementById('attribution').appendChild( attributionControl.getElement()); var keyboardInteraction = new ol.interaction.Keyboard(); keyboardInteraction.addCallback('0', function() { layer.setBrightness(0); layer.setContrast(0); layer.setHue(0); layer.setSaturation(0); layer.setOpacity(1); layer.setVisible(true); }); keyboardInteraction.addCallback('b', function() { layer.setBrightness(layer.getBrightness() - 0.1); }); keyboardInteraction.addCallback('B', function() { layer.setBrightness(layer.getBrightness() + 0.1); }); keyboardInteraction.addCallback('c', function() { layer.setContrast(layer.getContrast() - 0.1); }); keyboardInteraction.addCallback('C', function() { layer.setContrast(layer.getContrast() + 0.1); }); keyboardInteraction.addCallback('h', function() { layer.setHue(layer.getHue() - 0.1); }); keyboardInteraction.addCallback('H', function() { layer.setHue(layer.getHue() + 0.1); }); keyboardInteraction.addCallback('o', function() { layer.setOpacity(layer.getOpacity() - 0.1); }); keyboardInteraction.addCallback('O', function() { layer.setOpacity(layer.getOpacity() + 0.1); }); keyboardInteraction.addCallback('r', function() { webglMap.setRotation(0); }); keyboardInteraction.addCallback('s', function() { layer.setSaturation(layer.getSaturation() - 0.1); }); keyboardInteraction.addCallback('S', function() { layer.setSaturation(layer.getSaturation() + 0.1); }); keyboardInteraction.addCallback('vV', function() { layer.setVisible(!layer.getVisible()); }); domMap.getInteractions().push(keyboardInteraction); goog.exportSymbol('layer', layer); goog.exportSymbol('layers', layers); goog.exportSymbol('domMap', domMap); goog.exportSymbol('webglMap', webglMap);