Comparing version 3.0.0-beta7 to 3.0.0-beta8
@@ -60,4 +60,3 @@ 'use strict'; | ||
// Returns attributes in a format suitable for use with Luma.gl objects | ||
// | ||
// Returns attributes in a format suitable for use with Luma.gl Model/Program | ||
@@ -70,2 +69,5 @@ | ||
} | ||
// Returns the redraw flag | ||
}, { | ||
@@ -82,2 +84,5 @@ key: 'getNeedsRedraw', | ||
} | ||
// Adds a static attribute (that is not auto updated) | ||
}, { | ||
@@ -87,5 +92,7 @@ key: 'add', | ||
var newAttributes = this._add(attributes, updaters, {}); | ||
// and instancedAttributes (for updating when data changes) | ||
Object.assign(this.attributes, newAttributes); | ||
} | ||
// Adds a dynamic attribute, that is autoupdated | ||
}, { | ||
@@ -97,5 +104,7 @@ key: 'addDynamic', | ||
}); | ||
// and instancedAttributes (for updating when data changes) | ||
Object.assign(this.attributes, newAttributes); | ||
} | ||
// Adds an instanced attribute that is autoupdated | ||
}, { | ||
@@ -109,35 +118,5 @@ key: 'addInstanced', | ||
Object.assign(this.attributes, newAttributes); | ||
// and instancedAttributes (for updating when data changes) | ||
Object.assign(this.instancedAttributes, newAttributes); | ||
} | ||
}, { | ||
key: 'addVertices', | ||
value: function addVertices(vertexArray) { | ||
(0, _assert2.default)(vertexArray instanceof Float32Array); | ||
this.add({ | ||
vertices: { value: vertexArray, size: 3, '0': 'x', '1': 'y', '2': 'z' } | ||
}); | ||
} | ||
}, { | ||
key: 'addNormals', | ||
value: function addNormals(normalArray) { | ||
(0, _assert2.default)(normalArray instanceof Float32Array); | ||
this.add({ | ||
normals: { value: normalArray, size: 3, '0': 'x', '1': 'y', '2': 'z' } | ||
}); | ||
} | ||
}, { | ||
key: 'addIndices', | ||
value: function addIndices(indexArray, gl) { | ||
(0, _assert2.default)(indexArray instanceof Uint16Array); | ||
(0, _assert2.default)(gl); | ||
this.add({ | ||
indices: { | ||
value: indexArray, | ||
size: 1, | ||
bufferType: gl.ELEMENT_ARRAY_BUFFER, | ||
drawMode: gl.STATIC_DRAW, | ||
'0': 'index' | ||
} | ||
}); | ||
} | ||
@@ -426,2 +405,2 @@ // Marks an attribute for update | ||
exports.default = AttributeManager; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/attribute-manager.js"],"names":[],"mappings":"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","file":"attribute-manager.js","sourcesContent":["/* eslint-disable guard-for-in */\nimport log from './log';\nimport assert from 'assert';\n\n// auto: -\n// instanced: - implies auto\n//\nexport default class AttributeManager {\n\n  /**\n   * @classdesc\n   * Manages a list of attributes and an instance count\n   * Auto allocates and updates \"instanced\" attributes as necessary\n   *\n   * - keeps track of valid state for each attribute\n   * - auto reallocates attributes when needed\n   * - auto updates attributes with registered updater functions\n   * - allows overriding with application supplied buffers\n   */\n  constructor({id = ''}) {\n    this.id = id;\n    this.attributes = {};\n    this.instancedAttributes = {};\n    this.allocedInstances = -1;\n    this.needsRedraw = true;\n    this.userData = {};\n    // For debugging sanity, prevent uninitialized members\n    Object.seal(this);\n  }\n\n  // Returns attributes in a format suitable for use with Luma.gl objects\n  //\n  getAttributes() {\n    return this.attributes;\n  }\n\n  getNeedsRedraw({clearFlag}) {\n    const needsRedraw = this.needsRedraw;\n    if (clearFlag) {\n      this.needsRedraw = false;\n    }\n    return needsRedraw;\n  }\n\n  add(attributes, updaters) {\n    const newAttributes = this._add(attributes, updaters, {});\n    // and instancedAttributes (for updating when data changes)\n    Object.assign(this.attributes, newAttributes);\n  }\n\n  addDynamic(attributes, updaters) {\n    const newAttributes = this._add(attributes, updaters, {\n      autoUpdate: true\n    });\n    // and instancedAttributes (for updating when data changes)\n    Object.assign(this.attributes, newAttributes);\n  }\n\n  addInstanced(attributes, updaters) {\n    const newAttributes = this._add(attributes, updaters, {\n      instanced: 1,\n      autoUpdate: true\n    });\n    Object.assign(this.attributes, newAttributes);\n    Object.assign(this.instancedAttributes, newAttributes);\n  }\n\n  addVertices(vertexArray) {\n    assert(vertexArray instanceof Float32Array);\n    this.add({\n      vertices: {value: vertexArray, size: 3, '0': 'x', '1': 'y', '2': 'z'}\n    });\n  }\n\n  addNormals(normalArray) {\n    assert(normalArray instanceof Float32Array);\n    this.add({\n      normals: {value: normalArray, size: 3, '0': 'x', '1': 'y', '2': 'z'}\n    });\n  }\n\n  addIndices(indexArray, gl) {\n    assert(indexArray instanceof Uint16Array);\n    assert(gl);\n    this.add({\n      indices: {\n        value: indexArray,\n        size: 1,\n        bufferType: gl.ELEMENT_ARRAY_BUFFER,\n        drawMode: gl.STATIC_DRAW,\n        '0': 'index'\n      }\n    });\n  }\n\n  // Marks an attribute for update\n  invalidate(attributeName) {\n    const {attributes} = this;\n    const attribute = attributes[attributeName];\n    assert(attribute);\n    attribute.needsUpdate = true;\n  }\n\n  invalidateAll() {\n    const {attributes} = this;\n    for (const attributeName in attributes) {\n      const attribute = attributes[attributeName];\n      attribute.needsUpdate = true;\n    }\n  }\n\n  // Ensure all attribute buffers are updated from props or data\n  update({numInstances, buffers = {}, context, data, getValue, ...opts} = {}) {\n    this._checkBuffers(buffers, opts);\n    this._setBuffers(buffers);\n    this._allocateBuffers({numInstances});\n    this._updateBuffers({numInstances, context, data, getValue});\n  }\n\n  // Set the buffers for the supplied attributes\n  // Update attribute buffers from any attributes in props\n  // Detach any previously set buffers, marking all\n  // Attributes for auto allocation\n  _setBuffers(bufferMap, opt) {\n    const {attributes} = this;\n\n    // Copy the refs of any supplied buffers in the props\n    for (const attributeName in attributes) {\n      const attribute = attributes[attributeName];\n      const buffer = bufferMap[attributeName];\n      if (buffer) {\n        attribute.isExternalBuffer = true;\n        attribute.needsUpdate = false;\n        if (attribute.value !== buffer) {\n          attribute.value = buffer;\n          this.needsRedraw = true;\n        }\n      } else {\n        attribute.isExternalBuffer = false;\n      }\n    }\n  }\n\n  // Auto allocates buffers for attributes\n  // Note: To reduce allocations, only grows buffers\n  // Note: Only allocates buffers not set by setBuffer\n  _allocateBuffers({numInstances}) {\n    const {allocedInstances, attributes} = this;\n    assert(numInstances !== undefined);\n\n    if (numInstances > allocedInstances) {\n      // Allocate at least one element to ensure a valid buffer\n      const allocCount = Math.max(numInstances, 1);\n      for (const attributeName in attributes) {\n        const attribute = attributes[attributeName];\n        const {size, isExternalBuffer, autoUpdate} = attribute;\n        if (!isExternalBuffer && autoUpdate) {\n          const ArrayType = attribute.type || Float32Array;\n          attribute.value = new ArrayType(size * allocCount);\n          attribute.needsUpdate = true;\n          log(2, `autoallocated ${allocCount} ${attributeName} for ${this.id}`);\n        }\n      }\n      this.allocedInstances = allocCount;\n    }\n  }\n\n  _updateBuffers({numInstances, data, getValue, context}) {\n    const {attributes} = this;\n\n    // If app supplied all attributes, no need to iterate over data\n\n    for (const attributeName in attributes) {\n      const attribute = attributes[attributeName];\n      const {update} = attribute;\n      if (attribute.needsUpdate && attribute.autoUpdate) {\n        if (update) {\n          log(2,\n            `autoupdating ${numInstances} ${attributeName} for ${this.id}`);\n          update.call(context, attribute, numInstances);\n        } else {\n          log(2,\n            `autocalculating ${numInstances} ${attributeName} for ${this.id}`);\n          this._updateAttributeFromData(attribute, data, getValue);\n        }\n        attribute.needsUpdate = false;\n        this.needsRedraw = true;\n      }\n    }\n  }\n\n  _updateAttributeFromData(attribute, data = [], getValue = x => x) {\n\n    let i = 0;\n    for (const object of data) {\n      const values = getValue(object);\n      // If this attribute's buffer wasn't copied from props, initialize it\n      if (!attribute.isExternalBuffer) {\n        const {value, size} = attribute;\n        value[i * size + 0] = values[attribute[0]];\n        if (size >= 2) {\n          value[i * size + 1] = values[attribute[0]];\n        }\n        if (size >= 3) {\n          value[i * size + 2] = values[attribute[0]];\n        }\n        if (size >= 4) {\n          value[i * size + 3] = values[attribute[0]];\n        }\n      }\n      i++;\n    }\n  }\n\n  // Checks that any attribute buffers in props are valid\n  // Note: This is just to help app catch mistakes\n  _checkBuffers(bufferMap = {}, opts = {}) {\n    const {attributes, numInstances} = this;\n\n    for (const attributeName in bufferMap) {\n      const attribute = attributes[attributeName];\n      const buffer = bufferMap[attributeName];\n      if (!attribute && !opts.ignoreUnknownAttributes) {\n        throw new Error(`Unknown attribute prop ${attributeName}`);\n      }\n      if (attribute) {\n        if (!(buffer instanceof Float32Array)) {\n          throw new Error('Attribute properties must be of type Float32Array');\n        }\n        if (attribute.auto && buffer.length <= numInstances * attribute.size) {\n          throw new Error('Attribute prop array must match length and size');\n        }\n      }\n    }\n  }\n\n  // Used to register an attribute\n  _add(attributes, updaters, _extraProps = {}) {\n\n    const newAttributes = {};\n\n    for (const attributeName in attributes) {\n      const attribute = attributes[attributeName];\n      const updater = updaters && updaters[attributeName];\n\n      // Check all fields and generate helpful error messages\n      this._validate(attributeName, attribute, updater);\n\n      // Initialize the attribute descriptor, with WebGL and metadata fields\n      const attributeData = {\n        // Metadata\n        ...attribute,\n        ...updater,\n\n        // State\n        isExternalBuffer: false,\n        needsUpdate: true,\n\n        // Reserved for application\n        userData: {},\n\n        // WebGL fields\n        size: attribute.size,\n        value: attribute.value || null,\n\n        // buffer type\n        bufferType: undefined,\n        ..._extraProps\n      };\n      // Sanity - no app fields on our attributes. Use userData instead.\n      Object.seal(attributeData);\n\n      // Add to both attributes list (for registration with model)\n      this.attributes[attributeName] = attributeData;\n    }\n\n    return newAttributes;\n  }\n\n  _validate(attributeName, attribute, updater) {\n    assert(typeof attribute.size === 'number',\n      `Attribute definition for ${attributeName} missing size`);\n\n    // Check that value extraction keys are set\n    assert(typeof attribute[0] === 'string',\n      `Attribute definition for ${attributeName} missing key 0`);\n    if (attribute.size >= 2) {\n      assert(typeof attribute[1] === 'string',\n        `Attribute definition for ${attributeName} missing key 1`);\n    }\n    if (attribute.size >= 3) {\n      assert(typeof attribute[2] === 'string',\n        `Attribute definition for ${attributeName} missing key 2`);\n    }\n    if (attribute.size >= 4) {\n      assert(typeof attribute[3] === 'string',\n        `Attribute definition for ${attributeName} missing key 3`);\n    }\n\n    // Check the updater\n    assert(!updater || typeof updater.update === 'function',\n      `Attribute updater for ${attributeName} missing update method`);\n  }\n\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/attribute-manager.js"],"names":[],"mappings":"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","file":"attribute-manager.js","sourcesContent":["/* eslint-disable guard-for-in */\nimport log from './log';\nimport assert from 'assert';\n\n// auto: -\n// instanced: - implies auto\n//\nexport default class AttributeManager {\n\n  /**\n   * @classdesc\n   * Manages a list of attributes and an instance count\n   * Auto allocates and updates \"instanced\" attributes as necessary\n   *\n   * - keeps track of valid state for each attribute\n   * - auto reallocates attributes when needed\n   * - auto updates attributes with registered updater functions\n   * - allows overriding with application supplied buffers\n   */\n  constructor({id = ''}) {\n    this.id = id;\n    this.attributes = {};\n    this.instancedAttributes = {};\n    this.allocedInstances = -1;\n    this.needsRedraw = true;\n    this.userData = {};\n    // For debugging sanity, prevent uninitialized members\n    Object.seal(this);\n  }\n\n  // Returns attributes in a format suitable for use with Luma.gl Model/Program\n  getAttributes() {\n    return this.attributes;\n  }\n\n  // Returns the redraw flag\n  getNeedsRedraw({clearFlag}) {\n    const needsRedraw = this.needsRedraw;\n    if (clearFlag) {\n      this.needsRedraw = false;\n    }\n    return needsRedraw;\n  }\n\n  // Adds a static attribute (that is not auto updated)\n  add(attributes, updaters) {\n    const newAttributes = this._add(attributes, updaters, {});\n    Object.assign(this.attributes, newAttributes);\n  }\n\n  // Adds a dynamic attribute, that is autoupdated\n  addDynamic(attributes, updaters) {\n    const newAttributes = this._add(attributes, updaters, {\n      autoUpdate: true\n    });\n    Object.assign(this.attributes, newAttributes);\n  }\n\n  // Adds an instanced attribute that is autoupdated\n  addInstanced(attributes, updaters) {\n    const newAttributes = this._add(attributes, updaters, {\n      instanced: 1,\n      autoUpdate: true\n    });\n    Object.assign(this.attributes, newAttributes);\n    // and instancedAttributes (for updating when data changes)\n    Object.assign(this.instancedAttributes, newAttributes);\n  }\n\n  // Marks an attribute for update\n  invalidate(attributeName) {\n    const {attributes} = this;\n    const attribute = attributes[attributeName];\n    assert(attribute);\n    attribute.needsUpdate = true;\n  }\n\n  invalidateAll() {\n    const {attributes} = this;\n    for (const attributeName in attributes) {\n      const attribute = attributes[attributeName];\n      attribute.needsUpdate = true;\n    }\n  }\n\n  // Ensure all attribute buffers are updated from props or data\n  update({numInstances, buffers = {}, context, data, getValue, ...opts} = {}) {\n    this._checkBuffers(buffers, opts);\n    this._setBuffers(buffers);\n    this._allocateBuffers({numInstances});\n    this._updateBuffers({numInstances, context, data, getValue});\n  }\n\n  // Set the buffers for the supplied attributes\n  // Update attribute buffers from any attributes in props\n  // Detach any previously set buffers, marking all\n  // Attributes for auto allocation\n  _setBuffers(bufferMap, opt) {\n    const {attributes} = this;\n\n    // Copy the refs of any supplied buffers in the props\n    for (const attributeName in attributes) {\n      const attribute = attributes[attributeName];\n      const buffer = bufferMap[attributeName];\n      if (buffer) {\n        attribute.isExternalBuffer = true;\n        attribute.needsUpdate = false;\n        if (attribute.value !== buffer) {\n          attribute.value = buffer;\n          this.needsRedraw = true;\n        }\n      } else {\n        attribute.isExternalBuffer = false;\n      }\n    }\n  }\n\n  // Auto allocates buffers for attributes\n  // Note: To reduce allocations, only grows buffers\n  // Note: Only allocates buffers not set by setBuffer\n  _allocateBuffers({numInstances}) {\n    const {allocedInstances, attributes} = this;\n    assert(numInstances !== undefined);\n\n    if (numInstances > allocedInstances) {\n      // Allocate at least one element to ensure a valid buffer\n      const allocCount = Math.max(numInstances, 1);\n      for (const attributeName in attributes) {\n        const attribute = attributes[attributeName];\n        const {size, isExternalBuffer, autoUpdate} = attribute;\n        if (!isExternalBuffer && autoUpdate) {\n          const ArrayType = attribute.type || Float32Array;\n          attribute.value = new ArrayType(size * allocCount);\n          attribute.needsUpdate = true;\n          log(2, `autoallocated ${allocCount} ${attributeName} for ${this.id}`);\n        }\n      }\n      this.allocedInstances = allocCount;\n    }\n  }\n\n  _updateBuffers({numInstances, data, getValue, context}) {\n    const {attributes} = this;\n\n    // If app supplied all attributes, no need to iterate over data\n\n    for (const attributeName in attributes) {\n      const attribute = attributes[attributeName];\n      const {update} = attribute;\n      if (attribute.needsUpdate && attribute.autoUpdate) {\n        if (update) {\n          log(2,\n            `autoupdating ${numInstances} ${attributeName} for ${this.id}`);\n          update.call(context, attribute, numInstances);\n        } else {\n          log(2,\n            `autocalculating ${numInstances} ${attributeName} for ${this.id}`);\n          this._updateAttributeFromData(attribute, data, getValue);\n        }\n        attribute.needsUpdate = false;\n        this.needsRedraw = true;\n      }\n    }\n  }\n\n  _updateAttributeFromData(attribute, data = [], getValue = x => x) {\n\n    let i = 0;\n    for (const object of data) {\n      const values = getValue(object);\n      // If this attribute's buffer wasn't copied from props, initialize it\n      if (!attribute.isExternalBuffer) {\n        const {value, size} = attribute;\n        value[i * size + 0] = values[attribute[0]];\n        if (size >= 2) {\n          value[i * size + 1] = values[attribute[0]];\n        }\n        if (size >= 3) {\n          value[i * size + 2] = values[attribute[0]];\n        }\n        if (size >= 4) {\n          value[i * size + 3] = values[attribute[0]];\n        }\n      }\n      i++;\n    }\n  }\n\n  // Checks that any attribute buffers in props are valid\n  // Note: This is just to help app catch mistakes\n  _checkBuffers(bufferMap = {}, opts = {}) {\n    const {attributes, numInstances} = this;\n\n    for (const attributeName in bufferMap) {\n      const attribute = attributes[attributeName];\n      const buffer = bufferMap[attributeName];\n      if (!attribute && !opts.ignoreUnknownAttributes) {\n        throw new Error(`Unknown attribute prop ${attributeName}`);\n      }\n      if (attribute) {\n        if (!(buffer instanceof Float32Array)) {\n          throw new Error('Attribute properties must be of type Float32Array');\n        }\n        if (attribute.auto && buffer.length <= numInstances * attribute.size) {\n          throw new Error('Attribute prop array must match length and size');\n        }\n      }\n    }\n  }\n\n  // Used to register an attribute\n  _add(attributes, updaters, _extraProps = {}) {\n\n    const newAttributes = {};\n\n    for (const attributeName in attributes) {\n      const attribute = attributes[attributeName];\n      const updater = updaters && updaters[attributeName];\n\n      // Check all fields and generate helpful error messages\n      this._validate(attributeName, attribute, updater);\n\n      // Initialize the attribute descriptor, with WebGL and metadata fields\n      const attributeData = {\n        // Metadata\n        ...attribute,\n        ...updater,\n\n        // State\n        isExternalBuffer: false,\n        needsUpdate: true,\n\n        // Reserved for application\n        userData: {},\n\n        // WebGL fields\n        size: attribute.size,\n        value: attribute.value || null,\n\n        // buffer type\n        bufferType: undefined,\n        ..._extraProps\n      };\n      // Sanity - no app fields on our attributes. Use userData instead.\n      Object.seal(attributeData);\n\n      // Add to both attributes list (for registration with model)\n      this.attributes[attributeName] = attributeData;\n    }\n\n    return newAttributes;\n  }\n\n  _validate(attributeName, attribute, updater) {\n    assert(typeof attribute.size === 'number',\n      `Attribute definition for ${attributeName} missing size`);\n\n    // Check that value extraction keys are set\n    assert(typeof attribute[0] === 'string',\n      `Attribute definition for ${attributeName} missing key 0`);\n    if (attribute.size >= 2) {\n      assert(typeof attribute[1] === 'string',\n        `Attribute definition for ${attributeName} missing key 1`);\n    }\n    if (attribute.size >= 3) {\n      assert(typeof attribute[2] === 'string',\n        `Attribute definition for ${attributeName} missing key 2`);\n    }\n    if (attribute.size >= 4) {\n      assert(typeof attribute[3] === 'string',\n        `Attribute definition for ${attributeName} missing key 3`);\n    }\n\n    // Check the updater\n    assert(!updater || typeof updater.update === 'function',\n      `Attribute updater for ${attributeName} missing update method`);\n  }\n\n}\n"]} |
@@ -92,2 +92,4 @@ 'use strict'; | ||
var DEFAULT_PIXEL_RATIO = typeof window !== 'undefined' ? window.devicePixelRatio : 1; | ||
var PROP_TYPES = { | ||
@@ -100,3 +102,5 @@ width: _react.PropTypes.number.isRequired, | ||
// TODO - replace with actual map view state props, build matrix from those | ||
projectionMatrix: _react.PropTypes.any | ||
projectionMatrix: _react.PropTypes.any, | ||
pixelRatio: _react.PropTypes.number, | ||
onWebGLInitialized: _react.PropTypes.func | ||
}; | ||
@@ -107,3 +111,5 @@ | ||
camera: null, | ||
projectionMatrix: null | ||
projectionMatrix: null, | ||
pixelRatio: DEFAULT_PIXEL_RATIO, | ||
onWebGLInitialized: function onWebGLInitialized() {} | ||
}; | ||
@@ -199,2 +205,3 @@ | ||
this.props.onWebGLInitialized(gl); | ||
this.setState({ | ||
@@ -293,4 +300,5 @@ gl: gl, | ||
var projectionMatrix = _props.projectionMatrix; | ||
var pixelRatio = _props.pixelRatio; | ||
var otherProps = _objectWithoutProperties(_props, ['width', 'height', 'layers', 'blending', 'projectionMatrix']); | ||
var otherProps = _objectWithoutProperties(_props, ['width', 'height', 'layers', 'blending', 'projectionMatrix', 'pixelRatio']); | ||
@@ -337,3 +345,3 @@ var camera = this.props.camera; | ||
blending: blending, | ||
pixelRatio: window.devicePixelRatio, | ||
pixelRatio: pixelRatio, | ||
@@ -350,2 +358,2 @@ onRendererInitialized: this._onRendererInitialized, | ||
exports.default = DeckGLOverlay; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/deckgl-overlay.js"],"names":[],"mappings":"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","file":"deckgl-overlay.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* global window */\nimport React, {PropTypes} from 'react';\nimport autobind from 'autobind-decorator';\n\nimport WebGLRenderer from './webgl-renderer';\nimport {Scene, Camera, PerspectiveCamera, Mat4} from 'luma.gl';\nimport {DEFAULT_LIGHTING, DEFAULT_BLENDING, DEFAULT_BACKGROUND_COLOR}\n  from './config';\nimport {\n  matchLayers, finalizeOldLayers, updateMatchedLayers,\n  initializeNewLayers, layersNeedRedraw\n} from './layer-manager';\n\nconst PROP_TYPES = {\n  width: PropTypes.number.isRequired,\n  height: PropTypes.number.isRequired,\n  layers: PropTypes.array.isRequired,\n  blending: PropTypes.object,\n  camera: PropTypes.instanceOf(Camera),\n  // TODO - replace with actual map view state props, build matrix from those\n  projectionMatrix: PropTypes.any\n};\n\nconst DEFAULT_PROPS = {\n  blending: DEFAULT_BLENDING,\n  camera: null,\n  projectionMatrix: null\n};\n\nexport default class DeckGLOverlay extends React.Component {\n\n  static get propTypes() {\n    return PROP_TYPES;\n  }\n\n  static get defaultProps() {\n    return DEFAULT_PROPS;\n  }\n\n  constructor(props) {\n    super(props);\n    this.state = {};\n    this.needsRedraw = true;\n  }\n\n  componentWillReceiveProps(nextProps) {\n    matchLayers(this.props.layers, nextProps.layers);\n    finalizeOldLayers(this.props.layers);\n    updateMatchedLayers(nextProps.layers);\n    this.initializeLayers(nextProps.layers);\n  }\n\n  initializeLayers(layers) {\n    const {gl} = this.state;\n    if (!gl) {\n      return;\n    }\n    initializeNewLayers(layers, {gl});\n    this.addLayersToScene(layers);\n  }\n\n  addLayersToScene(layers) {\n    const {scene} = this.state;\n    if (!scene) {\n      return;\n    }\n    // clear scene and repopulate based on new layers\n    scene.removeAll();\n    for (const layer of layers) {\n      // Save layer on model for picking purposes\n      // TODO - store on model.userData rather than directly on model\n      layer.state.model.userData.layer = layer;\n      // Add model to scene\n      scene.add(layer.state.model);\n    }\n  }\n\n  @autobind\n  _onRendererInitialized({gl}) {\n    this.setState({\n      gl,\n      scene: new Scene(gl, {\n        lights: DEFAULT_LIGHTING,\n        backgroundColor: DEFAULT_BACKGROUND_COLOR\n      })\n    });\n    initializeNewLayers(this.props.layers, {gl});\n  }\n\n  // Route events to layers\n  @autobind\n  _onClick(info) {\n    const {picked} = info;\n    for (const item of picked) {\n      if (item.model.userData.layer.onClick({color: item.color, ...info})) {\n        return;\n      }\n    }\n  }\n\n    // Route events to layers\n  @autobind\n  _onMouseMove(info) {\n    const {picked} = info;\n    for (const item of picked) {\n      if (item.model.userData.layer.onHover({color: item.color, ...info})) {\n        return;\n      }\n    }\n  }\n\n  @autobind\n  _checkIfNeedRedraw() {\n    const {layers} = this.props;\n    return layersNeedRedraw(layers, {clearFlag: true});\n  }\n\n  render() {\n    const {\n      width, height, layers, blending, projectionMatrix, ...otherProps\n    } = this.props;\n    let {camera} = this.props;\n    const {scene} = this.state;\n\n    this.initializeLayers(layers);\n\n    // creating camera from projectionMatrix\n    // TODO move this to react-map-gl utility\n    // TODO should be able to build matrix from\n    // standard mabox props: lat/lon/zoom/pitch/bearing/altitude\n    if (!camera) {\n      camera = new PerspectiveCamera();\n      if (!projectionMatrix) {\n        /* eslint-disable no-console */\n        /* global console */\n        console.warn('DeckGLOverlay needs either camera or projectionMatrix');\n        /* eslint-enable no-console */\n      } else {\n        camera.view = new Mat4().id();\n        for (let i = 0; i < projectionMatrix.length; ++i) {\n          camera.projection[i] = projectionMatrix[i];\n        }\n      }\n    }\n\n    const viewport = {\n      x: 0,\n      y: 0,\n      width, height\n    };\n\n    return (\n      <WebGLRenderer\n        { ...otherProps }\n\n        width={ width }\n        height={ height }\n\n        viewport={ viewport }\n        camera={ camera }\n        scene={ scene }\n        blending={ blending }\n        pixelRatio={ window.devicePixelRatio }\n\n        onRendererInitialized={ this._onRendererInitialized }\n        onNeedRedraw={ this._checkIfNeedRedraw }\n        onMouseMove={ this._onMouseMove }\n        onClick={ this._onClick }/>\n    );\n  }\n\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/deckgl-overlay.js"],"names":[],"mappings":"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","file":"deckgl-overlay.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* global window */\nimport React, {PropTypes} from 'react';\nimport autobind from 'autobind-decorator';\n\nimport WebGLRenderer from './webgl-renderer';\nimport {Scene, Camera, PerspectiveCamera, Mat4} from 'luma.gl';\nimport {DEFAULT_LIGHTING, DEFAULT_BLENDING, DEFAULT_BACKGROUND_COLOR}\n  from './config';\nimport {\n  matchLayers, finalizeOldLayers, updateMatchedLayers,\n  initializeNewLayers, layersNeedRedraw\n} from './layer-manager';\n\nconst DEFAULT_PIXEL_RATIO = typeof window !== 'undefined' ? window.devicePixelRatio : 1;\n\nconst PROP_TYPES = {\n  width: PropTypes.number.isRequired,\n  height: PropTypes.number.isRequired,\n  layers: PropTypes.array.isRequired,\n  blending: PropTypes.object,\n  camera: PropTypes.instanceOf(Camera),\n  // TODO - replace with actual map view state props, build matrix from those\n  projectionMatrix: PropTypes.any,\n  pixelRatio: PropTypes.number,\n  onWebGLInitialized: PropTypes.func\n};\n\nconst DEFAULT_PROPS = {\n  blending: DEFAULT_BLENDING,\n  camera: null,\n  projectionMatrix: null,\n  pixelRatio: DEFAULT_PIXEL_RATIO,\n  onWebGLInitialized: () => {}\n};\n\nexport default class DeckGLOverlay extends React.Component {\n\n  static get propTypes() {\n    return PROP_TYPES;\n  }\n\n  static get defaultProps() {\n    return DEFAULT_PROPS;\n  }\n\n  constructor(props) {\n    super(props);\n    this.state = {};\n    this.needsRedraw = true;\n  }\n\n  componentWillReceiveProps(nextProps) {\n    matchLayers(this.props.layers, nextProps.layers);\n    finalizeOldLayers(this.props.layers);\n    updateMatchedLayers(nextProps.layers);\n    this.initializeLayers(nextProps.layers);\n  }\n\n  initializeLayers(layers) {\n    const {gl} = this.state;\n    if (!gl) {\n      return;\n    }\n    initializeNewLayers(layers, {gl});\n    this.addLayersToScene(layers);\n  }\n\n  addLayersToScene(layers) {\n    const {scene} = this.state;\n    if (!scene) {\n      return;\n    }\n    // clear scene and repopulate based on new layers\n    scene.removeAll();\n    for (const layer of layers) {\n      // Save layer on model for picking purposes\n      // TODO - store on model.userData rather than directly on model\n      layer.state.model.userData.layer = layer;\n      // Add model to scene\n      scene.add(layer.state.model);\n    }\n  }\n\n  @autobind\n  _onRendererInitialized({gl}) {\n    this.props.onWebGLInitialized(gl);\n    this.setState({\n      gl,\n      scene: new Scene(gl, {\n        lights: DEFAULT_LIGHTING,\n        backgroundColor: DEFAULT_BACKGROUND_COLOR\n      })\n    });\n    initializeNewLayers(this.props.layers, {gl});\n  }\n\n  // Route events to layers\n  @autobind\n  _onClick(info) {\n    const {picked} = info;\n    for (const item of picked) {\n      if (item.model.userData.layer.onClick({color: item.color, ...info})) {\n        return;\n      }\n    }\n  }\n\n    // Route events to layers\n  @autobind\n  _onMouseMove(info) {\n    const {picked} = info;\n    for (const item of picked) {\n      if (item.model.userData.layer.onHover({color: item.color, ...info})) {\n        return;\n      }\n    }\n  }\n\n  @autobind\n  _checkIfNeedRedraw() {\n    const {layers} = this.props;\n    return layersNeedRedraw(layers, {clearFlag: true});\n  }\n\n  render() {\n    const {\n      width, height, layers, blending, projectionMatrix, pixelRatio, ...otherProps\n    } = this.props;\n    let {camera} = this.props;\n    const {scene} = this.state;\n\n    this.initializeLayers(layers);\n\n    // creating camera from projectionMatrix\n    // TODO move this to react-map-gl utility\n    // TODO should be able to build matrix from\n    // standard mabox props: lat/lon/zoom/pitch/bearing/altitude\n    if (!camera) {\n      camera = new PerspectiveCamera();\n      if (!projectionMatrix) {\n        /* eslint-disable no-console */\n        /* global console */\n        console.warn('DeckGLOverlay needs either camera or projectionMatrix');\n        /* eslint-enable no-console */\n      } else {\n        camera.view = new Mat4().id();\n        for (let i = 0; i < projectionMatrix.length; ++i) {\n          camera.projection[i] = projectionMatrix[i];\n        }\n      }\n    }\n\n    const viewport = {\n      x: 0,\n      y: 0,\n      width, height\n    };\n\n    return (\n      <WebGLRenderer\n        { ...otherProps }\n\n        width={ width }\n        height={ height }\n\n        viewport={ viewport }\n        camera={ camera }\n        scene={ scene }\n        blending={ blending }\n        pixelRatio={ pixelRatio }\n\n        onRendererInitialized={ this._onRendererInitialized }\n        onNeedRedraw={ this._checkIfNeedRedraw }\n        onMouseMove={ this._onMouseMove }\n        onClick={ this._onClick }/>\n    );\n  }\n\n}\n"]} |
@@ -94,3 +94,3 @@ 'use strict'; | ||
var ATTRIBUTES = { | ||
pickingColors: { size: 3, '0': 'pickRed', '1': 'pickGreen', '2': 'pickBlue' } | ||
instancePickingColors: { size: 3, '0': 'pickRed', '1': 'pickGreen', '2': 'pickBlue' } | ||
}; | ||
@@ -420,7 +420,7 @@ | ||
var attributeManager = this.state.attributeManager; | ||
// All instanced layers get pickingColors attribute by default | ||
// All instanced layers get instancePickingColors attribute by default | ||
// Their shaders can use it to render a picking scene | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
pickingColors: { update: this.calculatePickingColors } | ||
instancePickingColors: { update: this.calculateInstancePickingColors } | ||
}); | ||
@@ -484,4 +484,4 @@ | ||
}, { | ||
key: 'calculatePickingColors', | ||
value: function calculatePickingColors(attribute, numInstances) { | ||
key: 'calculateInstancePickingColors', | ||
value: function calculateInstancePickingColors(attribute, numInstances) { | ||
var value = attribute.value; | ||
@@ -529,4 +529,5 @@ var size = attribute.size; | ||
info.index = this.decodePickingColor(color); | ||
if (Array.isArray(this.data)) { | ||
info.object = this.data[info.index]; | ||
// If props.data is an indexable array, get the object | ||
if (Array.isArray(this.props.data)) { | ||
info.object = this.props.data[info.index]; | ||
} | ||
@@ -542,2 +543,3 @@ info.geoCoords = this.unproject({ x: info.x, y: info.y }); | ||
var selectedPickingColor = new Float32Array(3); | ||
@@ -598,8 +600,3 @@ selectedPickingColor[0] = color[0]; | ||
this.setState({ | ||
viewport: { | ||
x: 0, | ||
y: 0, | ||
width: width, | ||
height: height | ||
}, | ||
viewport: { x: 0, y: 0, width: width, height: height }, | ||
mercator: (0, _viewportMercatorProject2.default)({ | ||
@@ -659,2 +656,2 @@ width: width, height: height, latitude: latitude, longitude: longitude, zoom: zoom, | ||
exports.default = Layer; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/layer.js"],"names":[],"mappings":"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","file":"layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* eslint-disable guard-for-in */\nimport AttributeManager from './attribute-manager';\nimport {areEqualShallow} from './util';\nimport {addIterator} from './util';\nimport log from './log';\nimport isDeepEqual from 'lodash.isequal';\nimport assert from 'assert';\nimport ViewportMercator from 'viewport-mercator-project';\n\n/*\n * @param {string} props.id - layer name\n * @param {array}  props.data - array of data instances\n * @param {number} props.width - viewport width, synced with MapboxGL\n * @param {number} props.height - viewport width, synced with MapboxGL\n * @param {bool} props.isPickable - whether layer response to mouse event\n * @param {bool} props.opacity - opacity of the layer\n */\nconst DEFAULT_PROPS = {\n  key: 0,\n  opacity: 0.8,\n  numInstances: undefined,\n  data: [],\n  isPickable: false,\n  deepCompare: false,\n  getValue: x => x,\n  onHover: () => {},\n  onClick: () => {},\n  // Update triggers: a key change detection mechanism in deck.gl\n  //\n  // The value of `updateTriggers` is a map with fields corresponding to\n  // attribute names (or `all`). Each field has a value which is an object,\n  // it can contain any amount of data. The data for each field is compared\n  // shallowly, and if a change is detected, the attribute is invalidated\n  // (all attributes are invalidated if the `all` key is used.)\n  // Note: updateTriggers are ignored by normal shallow comparison, so it is\n  // OK for the app to mint a new object on every render.\n  updateTriggers: {}\n};\n\nconst ATTRIBUTES = {\n  pickingColors: {size: 3, '0': 'pickRed', '1': 'pickGreen', '2': 'pickBlue'}\n};\n\nlet counter = 0;\n\nexport default class Layer {\n\n  static get attributes() {\n    return ATTRIBUTES;\n  }\n\n  /**\n   * @classdesc\n   * Base Layer class\n   *\n   * @class\n   * @param {object} props - See docs above\n   */\n  /* eslint-disable max-statements */\n  constructor(props) {\n\n    props = {\n      ...DEFAULT_PROPS,\n      ...props\n    };\n\n    // Add iterator to objects\n    // TODO - Modifying props is an anti-pattern\n    if (props.data) {\n      addIterator(props.data);\n      assert(props.data[Symbol.iterator], 'data prop must have an iterator');\n    }\n\n    this.checkProp(props.data, 'data');\n    this.checkProp(props.id, 'id');\n    this.checkProp(props.width, 'width');\n    this.checkProp(props.height, 'height');\n\n    this.checkProp(props.width, 'width');\n    this.checkProp(props.height, 'height');\n    this.checkProp(props.latitude, 'latitude');\n    this.checkProp(props.longitude, 'longitude');\n    this.checkProp(props.zoom, 'zoom');\n\n    this.props = props;\n    this.count = counter++;\n  }\n  /* eslint-enable max-statements */\n\n  // //////////////////////////////////////////////////\n  // LIFECYCLE METHODS, overridden by the layer subclasses\n\n  // Called once to set up the initial state\n  initializeState() {\n  }\n\n  // gl context is now available\n  didMount() {\n  }\n\n  shouldUpdate(oldProps, newProps) {\n    // Check update triggers, and invalidate props accordingly\n    if (this.checkUpdateTriggers(oldProps, newProps)) {\n      return true;\n    }\n    // If any props have changed, ignoring updateTriggers objects\n    // (updateTriggers are expected to be reminted on every update)\n    const equalShallow = areEqualShallow(newProps, oldProps, {\n      ignore: {updateTriggers: true}\n    });\n    if (!equalShallow) {\n      if (newProps.data !== oldProps.data) {\n        this.setState({dataChanged: true});\n      }\n      return true;\n    }\n    if (newProps.deepCompare && !isDeepEqual(newProps.data, oldProps.data)) {\n      // Support optional deep compare of data\n      // Note: this is quite inefficient, app should use buffer props instead\n      this.setState({dataChanged: true});\n      return true;\n    }\n    return false;\n  }\n\n  // Default implementation, all attributeManager will be updated\n  willReceiveProps(newProps) {\n    const {attributeManager} = this.state;\n    if (this.state.dataChanged) {\n      attributeManager.invalidateAll();\n    }\n  }\n\n  // gl context still available\n  willUnmount() {\n  }\n\n  // END LIFECYCLE METHODS\n  // //////////////////////////////////////////////////\n\n  // Public API\n\n  getNeedsRedraw({clearFlag}) {\n    // this method may be called by the render loop as soon a the layer\n    // has been created, so guard against uninitialized state\n    if (!this.state) {\n      return false;\n    }\n\n    const {attributeManager} = this.state;\n    let needsRedraw = attributeManager.getNeedsRedraw({clearFlag});\n    needsRedraw = needsRedraw || this.state.needsRedraw;\n    if (clearFlag) {\n      this.state.needsRedraw = false;\n    }\n    return needsRedraw;\n  }\n\n  // Updates selected state members and marks the object for redraw\n  setState(updateObject) {\n    Object.assign(this.state, updateObject);\n    this.state.needsRedraw = true;\n  }\n\n  // Updates selected state members and marks the object for redraw\n  setUniforms(uniformMap) {\n    if (this.state.model) {\n      this.state.model.setUniforms(uniformMap);\n    }\n    // TODO - set needsRedraw on the model?\n    this.state.needsRedraw = true;\n    log(3, 'layer.setUniforms', uniformMap);\n  }\n\n  // Use iteration (the only required capability on data) to get first element\n  getFirstObject() {\n    const {data} = this.props;\n    for (const object of data) {\n      return object;\n    }\n    return null;\n  }\n\n  // INTERNAL METHODS\n\n  // Deduces numer of instances. Intention is to support:\n  // - Explicit setting of numInstances\n  // - Auto-deduction for ES6 containers that define a size member\n  // - Auto-deduction for Classic Arrays via the built-in length attribute\n  // - Auto-deduction via arrays\n  getNumInstances(props) {\n    props = props || this.props;\n\n    // First check if the layer has set its own value\n    if (this.state && this.state.numInstances !== undefined) {\n      return this.state.numInstances;\n    }\n\n    // Check if app has provided an explicit value\n    if (props.numInstances !== undefined) {\n      return props.numInstances;\n    }\n\n    const {data} = props;\n\n    // Check if ES6 collection \"count\" function is available\n    if (data && typeof data.count === 'function') {\n      return data.count();\n    }\n\n    // Check if ES6 collection \"size\" attribute is set\n    if (data && data.size !== undefined) {\n      return data.size;\n    }\n\n    // Check if array length attribute is set\n    // Note: checking this last since some ES6 collections (Immutable.js)\n    // emit profuse warnings when trying to access `length` attribute\n    if (data && data.length !== undefined) {\n      return data.length;\n    }\n\n    throw new Error('Could not deduce numInstances');\n  }\n\n  // Internal Helpers\n\n  checkProps(oldProps, newProps) {\n    // Note: dataChanged might already be set\n    if (newProps.data !== oldProps.data) {\n      // Figure out data length\n      this.state.dataChanged = true;\n    }\n\n    const viewportChanged =\n      newProps.width !== oldProps.width ||\n      newProps.height !== oldProps.height ||\n      newProps.latitude !== oldProps.latitude ||\n      newProps.longitude !== oldProps.longitude ||\n      newProps.zoom !== oldProps.zoom;\n\n    this.setState({viewportChanged});\n  }\n\n  updateAttributes(props) {\n    const {attributeManager} = this.state;\n    const numInstances = this.getNumInstances(props);\n    // Figure out data length\n    attributeManager.update({\n      numInstances,\n      bufferMap: props,\n      context: this,\n      // Don't worry about non-attribute props\n      ignoreUnknownAttributes: true\n    });\n  }\n\n  updateBaseUniforms() {\n    this.setUniforms({\n      // apply gamma to opacity to make it visually \"linear\"\n      opacity: Math.pow(this.props.opacity || 0.8, 1 / 2.2)\n    });\n  }\n\n  // Check if any update triggers have changed, and invalidate\n  // attributes accordingly.\n  checkUpdateTriggers(oldProps, newProps) {\n    let change = false;\n    const {attributeManager} = this.state;\n    for (const propName in newProps.updateTriggers) {\n      const oldTriggers = oldProps.updateTriggers[propName];\n      const newTriggers = newProps.updateTriggers[propName];\n      if (!areEqualShallow(oldTriggers, newTriggers)) {\n        if (propName === 'all') {\n          attributeManager.invalidateAll();\n          change = true;\n        } else {\n          attributeManager.invalidate(propName);\n          change = true;\n        }\n      }\n    }\n    return change;\n  }\n\n  // LAYER MANAGER API\n\n  // Called by layer manager when a new layer is found\n  initializeLayer({gl}) {\n    assert(gl);\n    this.state = {gl};\n\n    // Initialize state only once\n    this.setState({\n      attributeManager: new AttributeManager({id: this.props.id}),\n      model: null,\n      needsRedraw: true,\n      dataChanged: true\n    });\n\n    const {attributeManager} = this.state;\n    // All instanced layers get pickingColors attribute by default\n    // Their shaders can use it to render a picking scene\n    attributeManager.addInstanced(ATTRIBUTES, {\n      pickingColors: {update: this.calculatePickingColors}\n    });\n\n    this.setViewport();\n    this.initializeState();\n    assert(this.state.model, 'Model must be set in initializeState');\n    this.setViewport();\n\n    // TODO - the app must be able to override\n\n    // Add any subclass attributes\n    this.updateAttributes(this.props);\n    this.updateBaseUniforms();\n    this.state.model.setInstanceCount(this.getNumInstances());\n\n    // Create a model for the layer\n    this._updateModel({gl});\n\n    // Call life cycle method\n    this.didMount();\n  }\n\n  // Called by layer manager when existing layer is getting new props\n  updateLayer(oldProps, newProps) {\n    // Calculate standard change flags\n    this.checkProps(oldProps, newProps);\n\n    // Check if any props have changed\n    if (this.shouldUpdate(oldProps, newProps)) {\n      if (this.state.viewportChanged) {\n        this.setViewport();\n      }\n\n      // Let the subclass mark what is needed for update\n      this.willReceiveProps(oldProps, newProps);\n      // Run the attribute updaters\n      this.updateAttributes(newProps);\n      // Update the uniforms\n      this.updateBaseUniforms();\n\n      this.state.model.setInstanceCount(this.getNumInstances());\n    }\n\n    this.state.dataChanged = false;\n    this.state.viewportChanged = false;\n  }\n\n  // Called by manager when layer is about to be disposed\n  // Note: not guaranteed to be called on application shutdown\n  finalizeLayer() {\n    this.willUnmount();\n  }\n\n  calculatePickingColors(attribute, numInstances) {\n    const {value, size} = attribute;\n    // add 1 to index to seperate from no selection\n    for (let i = 0; i < numInstances; i++) {\n      const pickingColor = this.encodePickingColor(i);\n      value[i * size + 0] = pickingColor[0];\n      value[i * size + 1] = pickingColor[1];\n      value[i * size + 2] = pickingColor[2];\n    }\n  }\n\n  decodePickingColor(color) {\n    assert(color instanceof Uint8Array);\n    const [i1, i2, i3] = color;\n    // 1 was added to seperate from no selection\n    const index = i1 + i2 * 256 + i3 * 65536 - 1;\n    return index;\n  }\n\n  encodePickingColor(i) {\n    return [\n      (i + 1) % 256,\n      Math.floor((i + 1) / 256) % 256,\n      Math.floor((i + 1) / 256 / 256) % 256\n    ];\n  }\n\n  // VIRTUAL METHOD - Override to add or modify `info` object in sublayer\n  // The sublayer may know what object e.g. lat,lon corresponds to using math\n  // etc even when picking does not work\n  onGetHoverInfo(info) {\n    const {color} = info;\n    info.index = this.decodePickingColor(color);\n    if (Array.isArray(this.data)) {\n      info.object = this.data[info.index];\n    }\n    info.geoCoords = this.unproject({x: info.x, y: info.y});\n    return info;\n  }\n\n  onHover(info) {\n    const {color} = info;\n    const selectedPickingColor = new Float32Array(3);\n    selectedPickingColor[0] = color[0];\n    selectedPickingColor[1] = color[1];\n    selectedPickingColor[2] = color[2];\n    this.setUniforms({selectedPickingColor});\n\n    info = this.onGetHoverInfo(info);\n    return this.props.onHover(info);\n  }\n\n  onClick(info) {\n    info = this.onGetHoverInfo(info);\n    return this.props.onClick(info);\n  }\n\n  // INTERNAL METHODS\n  _updateModel({gl}) {\n    const {model, attributeManager, uniforms} = this.state;\n\n    assert(model);\n    model.setAttributes(attributeManager.getAttributes());\n    model.setUniforms(uniforms);\n    // whether current layer responds to mouse events\n    model.setPickable(this.props.isPickable);\n  }\n\n  checkProp(property, propertyName) {\n    if (!property) {\n      throw new Error(`Property ${propertyName} undefined in layer ${this.id}`);\n    }\n  }\n\n  // MAP LAYER FUNCTIONALITY\n\n  setViewport() {\n    const {width, height, latitude, longitude, zoom} = this.props;\n    this.setState({\n      viewport: {\n        x: 0,\n        y: 0,\n        width,\n        height\n      },\n      mercator: ViewportMercator({\n        width, height, latitude, longitude, zoom,\n        tileSize: 512\n      })\n    });\n    this.setUniforms({\n      viewport: [0, 0, width, height],\n      mercatorZoom: zoom,\n      mercatorCenter: [longitude, latitude]\n    });\n    log(3, this.state.viewport, latitude, longitude, zoom);\n  }\n\n  /**\n   * Position conversion is done in shader, so in many cases there is no need\n   * for this function\n   * @param {Object|Array} latLng - Either [lat,lng] or {lat, lon}\n   * @return {Object} - x, y\n   */\n  project(latLng) {\n    const {mercator} = this.state;\n    const [x, y] = Array.isArray(latLng) ?\n      mercator.project([latLng[1], latLng[0]]) :\n      mercator.project([latLng.lon, latLng.lat]);\n    return {x, y};\n  }\n\n  unproject(xy) {\n    const {mercator} = this.state;\n    const [lon, lat] = Array.isArray(xy) ?\n      mercator.unproject(xy) :\n      mercator.unproject([xy.x, xy.y]);\n    return {lat, lon};\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/layer.js"],"names":[],"mappings":"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","file":"layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* eslint-disable guard-for-in */\nimport AttributeManager from './attribute-manager';\nimport {areEqualShallow} from './util';\nimport {addIterator} from './util';\nimport log from './log';\nimport isDeepEqual from 'lodash.isequal';\nimport assert from 'assert';\nimport ViewportMercator from 'viewport-mercator-project';\n\n/*\n * @param {string} props.id - layer name\n * @param {array}  props.data - array of data instances\n * @param {number} props.width - viewport width, synced with MapboxGL\n * @param {number} props.height - viewport width, synced with MapboxGL\n * @param {bool} props.isPickable - whether layer response to mouse event\n * @param {bool} props.opacity - opacity of the layer\n */\nconst DEFAULT_PROPS = {\n  key: 0,\n  opacity: 0.8,\n  numInstances: undefined,\n  data: [],\n  isPickable: false,\n  deepCompare: false,\n  getValue: x => x,\n  onHover: () => {},\n  onClick: () => {},\n  // Update triggers: a key change detection mechanism in deck.gl\n  //\n  // The value of `updateTriggers` is a map with fields corresponding to\n  // attribute names (or `all`). Each field has a value which is an object,\n  // it can contain any amount of data. The data for each field is compared\n  // shallowly, and if a change is detected, the attribute is invalidated\n  // (all attributes are invalidated if the `all` key is used.)\n  // Note: updateTriggers are ignored by normal shallow comparison, so it is\n  // OK for the app to mint a new object on every render.\n  updateTriggers: {}\n};\n\nconst ATTRIBUTES = {\n  instancePickingColors:\n    {size: 3, '0': 'pickRed', '1': 'pickGreen', '2': 'pickBlue'}\n};\n\nlet counter = 0;\n\nexport default class Layer {\n\n  static get attributes() {\n    return ATTRIBUTES;\n  }\n\n  /**\n   * @classdesc\n   * Base Layer class\n   *\n   * @class\n   * @param {object} props - See docs above\n   */\n  /* eslint-disable max-statements */\n  constructor(props) {\n\n    props = {\n      ...DEFAULT_PROPS,\n      ...props\n    };\n\n    // Add iterator to objects\n    // TODO - Modifying props is an anti-pattern\n    if (props.data) {\n      addIterator(props.data);\n      assert(props.data[Symbol.iterator], 'data prop must have an iterator');\n    }\n\n    this.checkProp(props.data, 'data');\n    this.checkProp(props.id, 'id');\n    this.checkProp(props.width, 'width');\n    this.checkProp(props.height, 'height');\n\n    this.checkProp(props.width, 'width');\n    this.checkProp(props.height, 'height');\n    this.checkProp(props.latitude, 'latitude');\n    this.checkProp(props.longitude, 'longitude');\n    this.checkProp(props.zoom, 'zoom');\n\n    this.props = props;\n    this.count = counter++;\n  }\n  /* eslint-enable max-statements */\n\n  // //////////////////////////////////////////////////\n  // LIFECYCLE METHODS, overridden by the layer subclasses\n\n  // Called once to set up the initial state\n  initializeState() {\n  }\n\n  // gl context is now available\n  didMount() {\n  }\n\n  shouldUpdate(oldProps, newProps) {\n    // Check update triggers, and invalidate props accordingly\n    if (this.checkUpdateTriggers(oldProps, newProps)) {\n      return true;\n    }\n    // If any props have changed, ignoring updateTriggers objects\n    // (updateTriggers are expected to be reminted on every update)\n    const equalShallow = areEqualShallow(newProps, oldProps, {\n      ignore: {updateTriggers: true}\n    });\n    if (!equalShallow) {\n      if (newProps.data !== oldProps.data) {\n        this.setState({dataChanged: true});\n      }\n      return true;\n    }\n    if (newProps.deepCompare && !isDeepEqual(newProps.data, oldProps.data)) {\n      // Support optional deep compare of data\n      // Note: this is quite inefficient, app should use buffer props instead\n      this.setState({dataChanged: true});\n      return true;\n    }\n    return false;\n  }\n\n  // Default implementation, all attributeManager will be updated\n  willReceiveProps(newProps) {\n    const {attributeManager} = this.state;\n    if (this.state.dataChanged) {\n      attributeManager.invalidateAll();\n    }\n  }\n\n  // gl context still available\n  willUnmount() {\n  }\n\n  // END LIFECYCLE METHODS\n  // //////////////////////////////////////////////////\n\n  // Public API\n\n  getNeedsRedraw({clearFlag}) {\n    // this method may be called by the render loop as soon a the layer\n    // has been created, so guard against uninitialized state\n    if (!this.state) {\n      return false;\n    }\n\n    const {attributeManager} = this.state;\n    let needsRedraw = attributeManager.getNeedsRedraw({clearFlag});\n    needsRedraw = needsRedraw || this.state.needsRedraw;\n    if (clearFlag) {\n      this.state.needsRedraw = false;\n    }\n    return needsRedraw;\n  }\n\n  // Updates selected state members and marks the object for redraw\n  setState(updateObject) {\n    Object.assign(this.state, updateObject);\n    this.state.needsRedraw = true;\n  }\n\n  // Updates selected state members and marks the object for redraw\n  setUniforms(uniformMap) {\n    if (this.state.model) {\n      this.state.model.setUniforms(uniformMap);\n    }\n    // TODO - set needsRedraw on the model?\n    this.state.needsRedraw = true;\n    log(3, 'layer.setUniforms', uniformMap);\n  }\n\n  // Use iteration (the only required capability on data) to get first element\n  getFirstObject() {\n    const {data} = this.props;\n    for (const object of data) {\n      return object;\n    }\n    return null;\n  }\n\n  // INTERNAL METHODS\n\n  // Deduces numer of instances. Intention is to support:\n  // - Explicit setting of numInstances\n  // - Auto-deduction for ES6 containers that define a size member\n  // - Auto-deduction for Classic Arrays via the built-in length attribute\n  // - Auto-deduction via arrays\n  getNumInstances(props) {\n    props = props || this.props;\n\n    // First check if the layer has set its own value\n    if (this.state && this.state.numInstances !== undefined) {\n      return this.state.numInstances;\n    }\n\n    // Check if app has provided an explicit value\n    if (props.numInstances !== undefined) {\n      return props.numInstances;\n    }\n\n    const {data} = props;\n\n    // Check if ES6 collection \"count\" function is available\n    if (data && typeof data.count === 'function') {\n      return data.count();\n    }\n\n    // Check if ES6 collection \"size\" attribute is set\n    if (data && data.size !== undefined) {\n      return data.size;\n    }\n\n    // Check if array length attribute is set\n    // Note: checking this last since some ES6 collections (Immutable.js)\n    // emit profuse warnings when trying to access `length` attribute\n    if (data && data.length !== undefined) {\n      return data.length;\n    }\n\n    throw new Error('Could not deduce numInstances');\n  }\n\n  // Internal Helpers\n\n  checkProps(oldProps, newProps) {\n    // Note: dataChanged might already be set\n    if (newProps.data !== oldProps.data) {\n      // Figure out data length\n      this.state.dataChanged = true;\n    }\n\n    const viewportChanged =\n      newProps.width !== oldProps.width ||\n      newProps.height !== oldProps.height ||\n      newProps.latitude !== oldProps.latitude ||\n      newProps.longitude !== oldProps.longitude ||\n      newProps.zoom !== oldProps.zoom;\n\n    this.setState({viewportChanged});\n  }\n\n  updateAttributes(props) {\n    const {attributeManager} = this.state;\n    const numInstances = this.getNumInstances(props);\n    // Figure out data length\n    attributeManager.update({\n      numInstances,\n      bufferMap: props,\n      context: this,\n      // Don't worry about non-attribute props\n      ignoreUnknownAttributes: true\n    });\n  }\n\n  updateBaseUniforms() {\n    this.setUniforms({\n      // apply gamma to opacity to make it visually \"linear\"\n      opacity: Math.pow(this.props.opacity || 0.8, 1 / 2.2)\n    });\n  }\n\n  // Check if any update triggers have changed, and invalidate\n  // attributes accordingly.\n  checkUpdateTriggers(oldProps, newProps) {\n    let change = false;\n    const {attributeManager} = this.state;\n    for (const propName in newProps.updateTriggers) {\n      const oldTriggers = oldProps.updateTriggers[propName];\n      const newTriggers = newProps.updateTriggers[propName];\n      if (!areEqualShallow(oldTriggers, newTriggers)) {\n        if (propName === 'all') {\n          attributeManager.invalidateAll();\n          change = true;\n        } else {\n          attributeManager.invalidate(propName);\n          change = true;\n        }\n      }\n    }\n    return change;\n  }\n\n  // LAYER MANAGER API\n\n  // Called by layer manager when a new layer is found\n  initializeLayer({gl}) {\n    assert(gl);\n    this.state = {gl};\n\n    // Initialize state only once\n    this.setState({\n      attributeManager: new AttributeManager({id: this.props.id}),\n      model: null,\n      needsRedraw: true,\n      dataChanged: true\n    });\n\n    const {attributeManager} = this.state;\n    // All instanced layers get instancePickingColors attribute by default\n    // Their shaders can use it to render a picking scene\n    attributeManager.addInstanced(ATTRIBUTES, {\n      instancePickingColors: {update: this.calculateInstancePickingColors}\n    });\n\n    this.setViewport();\n    this.initializeState();\n    assert(this.state.model, 'Model must be set in initializeState');\n    this.setViewport();\n\n    // TODO - the app must be able to override\n\n    // Add any subclass attributes\n    this.updateAttributes(this.props);\n    this.updateBaseUniforms();\n    this.state.model.setInstanceCount(this.getNumInstances());\n\n    // Create a model for the layer\n    this._updateModel({gl});\n\n    // Call life cycle method\n    this.didMount();\n  }\n\n  // Called by layer manager when existing layer is getting new props\n  updateLayer(oldProps, newProps) {\n    // Calculate standard change flags\n    this.checkProps(oldProps, newProps);\n\n    // Check if any props have changed\n    if (this.shouldUpdate(oldProps, newProps)) {\n      if (this.state.viewportChanged) {\n        this.setViewport();\n      }\n\n      // Let the subclass mark what is needed for update\n      this.willReceiveProps(oldProps, newProps);\n      // Run the attribute updaters\n      this.updateAttributes(newProps);\n      // Update the uniforms\n      this.updateBaseUniforms();\n\n      this.state.model.setInstanceCount(this.getNumInstances());\n    }\n\n    this.state.dataChanged = false;\n    this.state.viewportChanged = false;\n  }\n\n  // Called by manager when layer is about to be disposed\n  // Note: not guaranteed to be called on application shutdown\n  finalizeLayer() {\n    this.willUnmount();\n  }\n\n  calculateInstancePickingColors(attribute, numInstances) {\n    const {value, size} = attribute;\n    // add 1 to index to seperate from no selection\n    for (let i = 0; i < numInstances; i++) {\n      const pickingColor = this.encodePickingColor(i);\n      value[i * size + 0] = pickingColor[0];\n      value[i * size + 1] = pickingColor[1];\n      value[i * size + 2] = pickingColor[2];\n    }\n  }\n\n  decodePickingColor(color) {\n    assert(color instanceof Uint8Array);\n    const [i1, i2, i3] = color;\n    // 1 was added to seperate from no selection\n    const index = i1 + i2 * 256 + i3 * 65536 - 1;\n    return index;\n  }\n\n  encodePickingColor(i) {\n    return [\n      (i + 1) % 256,\n      Math.floor((i + 1) / 256) % 256,\n      Math.floor((i + 1) / 256 / 256) % 256\n    ];\n  }\n\n  // VIRTUAL METHOD - Override to add or modify `info` object in sublayer\n  // The sublayer may know what object e.g. lat,lon corresponds to using math\n  // etc even when picking does not work\n  onGetHoverInfo(info) {\n    const {color} = info;\n    info.index = this.decodePickingColor(color);\n    // If props.data is an indexable array, get the object\n    if (Array.isArray(this.props.data)) {\n      info.object = this.props.data[info.index];\n    }\n    info.geoCoords = this.unproject({x: info.x, y: info.y});\n    return info;\n  }\n\n  onHover(info) {\n    const {color} = info;\n\n    const selectedPickingColor = new Float32Array(3);\n    selectedPickingColor[0] = color[0];\n    selectedPickingColor[1] = color[1];\n    selectedPickingColor[2] = color[2];\n    this.setUniforms({selectedPickingColor});\n\n    info = this.onGetHoverInfo(info);\n    return this.props.onHover(info);\n  }\n\n  onClick(info) {\n    info = this.onGetHoverInfo(info);\n    return this.props.onClick(info);\n  }\n\n  // INTERNAL METHODS\n  _updateModel({gl}) {\n    const {model, attributeManager, uniforms} = this.state;\n\n    assert(model);\n    model.setAttributes(attributeManager.getAttributes());\n    model.setUniforms(uniforms);\n    // whether current layer responds to mouse events\n    model.setPickable(this.props.isPickable);\n  }\n\n  checkProp(property, propertyName) {\n    if (!property) {\n      throw new Error(`Property ${propertyName} undefined in layer ${this.id}`);\n    }\n  }\n\n  // MAP LAYER FUNCTIONALITY\n\n  setViewport() {\n    const {width, height, latitude, longitude, zoom} = this.props;\n    this.setState({\n      viewport: {x: 0, y: 0, width, height},\n      mercator: ViewportMercator({\n        width, height, latitude, longitude, zoom,\n        tileSize: 512\n      })\n    });\n    this.setUniforms({\n      viewport: [0, 0, width, height],\n      mercatorZoom: zoom,\n      mercatorCenter: [longitude, latitude]\n    });\n    log(3, this.state.viewport, latitude, longitude, zoom);\n  }\n\n  /**\n   * Position conversion is done in shader, so in many cases there is no need\n   * for this function\n   * @param {Object|Array} latLng - Either [lat,lng] or {lat, lon}\n   * @return {Object} - x, y\n   */\n  project(latLng) {\n    const {mercator} = this.state;\n    const [x, y] = Array.isArray(latLng) ?\n      mercator.project([latLng[1], latLng[0]]) :\n      mercator.project([latLng.lon, latLng.lat]);\n    return {x, y};\n  }\n\n  unproject(xy) {\n    const {mercator} = this.state;\n    const [lon, lat] = Array.isArray(xy) ?\n      mercator.unproject(xy) :\n      mercator.unproject([xy.x, xy.y]);\n    return {lat, lon};\n  }\n}\n"]} |
@@ -24,2 +24,4 @@ 'use strict'; | ||
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } | ||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } | ||
@@ -52,3 +54,3 @@ | ||
var ATTRIBUTES = { | ||
positions: { size: 4, '0': 'x0', '1': 'y0', '2': 'x1', '3': 'y1' } | ||
instancePositions: { size: 4, '0': 'x0', '1': 'y0', '2': 'x1', '3': 'y1' } | ||
}; | ||
@@ -67,7 +69,20 @@ | ||
function ArcLayer(opts) { | ||
function ArcLayer() { | ||
var _ref = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; | ||
var _ref$strokeWidth = _ref.strokeWidth; | ||
var strokeWidth = _ref$strokeWidth === undefined ? 1 : _ref$strokeWidth; | ||
var _ref$color = _ref.color0; | ||
var color0 = _ref$color === undefined ? [255, 0, 0] : _ref$color; | ||
var _ref$color2 = _ref.color1; | ||
var color1 = _ref$color2 === undefined ? [0, 0, 255] : _ref$color2; | ||
var opts = _objectWithoutProperties(_ref, ['strokeWidth', 'color0', 'color1']); | ||
_classCallCheck(this, ArcLayer); | ||
return _possibleConstructorReturn(this, Object.getPrototypeOf(ArcLayer).call(this, _extends({ | ||
strokeWidth: 1 | ||
strokeWidth: strokeWidth, | ||
color0: color0, | ||
color1: color1 | ||
}, opts))); | ||
@@ -89,3 +104,3 @@ } | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
positions: { update: this.calculatePositions } | ||
instancePositions: { update: this.calculateInstancePositions } | ||
}); | ||
@@ -98,6 +113,4 @@ | ||
value: function willReceiveProps(oldProps, nextProps) { | ||
_get(Object.getPrototypeOf(ArcLayer.prototype), 'willReceiveProps', this).call(this, oldProps, nextProps); | ||
this.state.model.userData.strokeWidth = nextProps.strokeWidth; | ||
this.updateColors(); | ||
@@ -108,6 +121,6 @@ } | ||
value: function createModel(gl) { | ||
var vertices = []; | ||
var positions = []; | ||
var NUM_SEGMENTS = 50; | ||
for (var i = 0; i < NUM_SEGMENTS; i++) { | ||
vertices = [].concat(_toConsumableArray(vertices), [i, i, i]); | ||
positions = [].concat(_toConsumableArray(positions), [i, i, i]); | ||
} | ||
@@ -117,4 +130,4 @@ | ||
program: new _luma.Program(gl, { | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* vertex shader for the arc-layer */\n#define SHADER_NAME arc-layer-vs\n\n// viewport: [x, y, width, height]\nconst float TILE_SIZE_1540259130 = 512.0;\nconst float PI = 3.1415926536;\n\n// non-linear projection: lnglats => zoom level depdendent projected coords\nvec2 mercatorProject(vec2 lnglat, float zoom) {\n // Note: Could be precomputed, at the expense of less simple API\n float scale = pow(2.0, zoom) * TILE_SIZE_1540259130 / (PI * 2.0);\n\n float longitude = lnglat.x;\n float latitude = lnglat.y;\n\n float lamda = radians(longitude);\n float phi = radians(latitude);\n\n float x = scale * (lamda + PI);\n float y = scale * (PI - log(tan(PI * 0.25 + phi * 0.5)));\n\n return vec2(x, y);\n}\n\nuniform float mercatorZoom;\n\nconst float N = 49.0;\n\nattribute vec3 vertices;\nattribute vec4 positions;\n\nuniform mat4 worldMatrix;\nuniform mat4 projectionMatrix;\n\nvarying float ratio;\n\nfloat paraboloid(vec2 source, vec2 target, float index) {\n float ratio = index / N;\n\n vec2 x = mix(source, target, ratio);\n vec2 center = mix(source, target, 0.5);\n\n float dSourceCenter = distance(source, center);\n float dXCenter = distance(x, center);\n return (dSourceCenter + dXCenter) * (dSourceCenter - dXCenter);\n}\n\nvoid main(void) {\n vec2 source = mercatorProject(positions.xy, mercatorZoom);\n vec2 target = mercatorProject(positions.zw, mercatorZoom);\n\n float segmentIndex = vertices.x;\n vec3 p = vec3(\n // xy: linear interpolation of source & target\n mix(source, target, segmentIndex / N),\n // z: paraboloid interpolate of source & target\n sqrt(paraboloid(source, target, segmentIndex))\n );\n\n gl_Position = projectionMatrix * worldMatrix * vec4(p, 1.0);\n\n // map arc distance to color in fragment shader\n ratio = clamp(distance(source, target) / 1000.0, 0.0, 1.0);\n}\n', | ||
fs: '// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* fragment shader for the arc-layer */\n#define SHADER_NAME arc-layer-fs\n\n#ifdef GL_ES\nprecision highp float;\n#define GLSLIFY 1\n#endif\n\nuniform vec3 color0;\nuniform vec3 color1;\nuniform float opacity;\n\nvarying float ratio;\n\nvoid main(void) {\n gl_FragColor = vec4(mix(color0 / 255.0, color1 / 255.0, ratio), opacity);\n}\n', | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* vertex shader for the arc-layer */\n#define SHADER_NAME arc-layer-vs\n\n// viewport: [x, y, width, height]\nconst float TILE_SIZE_1540259130 = 512.0;\nconst float PI = 3.1415926536;\n\n// non-linear projection: lnglats => zoom level depdendent projected coords\nvec2 mercatorProject(vec2 lnglat, float zoom) {\n // Note: Could be precomputed, at the expense of less simple API\n float scale = pow(2.0, zoom) * TILE_SIZE_1540259130 / (PI * 2.0);\n\n float longitude = lnglat.x;\n float latitude = lnglat.y;\n\n float lamda = radians(longitude);\n float phi = radians(latitude);\n\n float x = scale * (lamda + PI);\n float y = scale * (PI - log(tan(PI * 0.25 + phi * 0.5)));\n\n return vec2(x, y);\n}\n\nuniform float mercatorZoom;\n\nconst float N = 49.0;\n\nattribute vec3 vertices;\nattribute vec4 instancePositions;\nattribute vec3 instancePickingColors;\n\nuniform mat4 worldMatrix;\nuniform mat4 projectionMatrix;\n\nvarying float ratio;\nvarying vec3 pickingColor;\n\nfloat paraboloid(vec2 source, vec2 target, float index) {\n float ratio = index / N;\n\n vec2 x = mix(source, target, ratio);\n vec2 center = mix(source, target, 0.5);\n\n float dSourceCenter = distance(source, center);\n float dXCenter = distance(x, center);\n return (dSourceCenter + dXCenter) * (dSourceCenter - dXCenter);\n}\n\nvoid main(void) {\n vec2 source = mercatorProject(instancePositions.xy, mercatorZoom);\n vec2 target = mercatorProject(instancePositions.zw, mercatorZoom);\n\n // TODO - are we only using x coordinate?\n float segmentIndex = vertices.x;\n vec3 p = vec3(\n // xy: linear interpolation of source & target\n mix(source, target, segmentIndex / N),\n // z: paraboloid interpolate of source & target\n sqrt(paraboloid(source, target, segmentIndex))\n );\n\n gl_Position = projectionMatrix * worldMatrix * vec4(p, 1.0);\n\n // map arc distance to color in fragment shader\n ratio = clamp(distance(source, target) / 1000.0, 0.0, 1.0);\n pickingColor = instancePickingColors;\n}\n', | ||
fs: '// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* fragment shader for the arc-layer */\n#define SHADER_NAME arc-layer-fs\n\n#ifdef GL_ES\nprecision highp float;\n#define GLSLIFY 1\n#endif\n\nuniform vec3 color0;\nuniform vec3 color1;\nuniform float opacity;\nuniform float renderPickingBuffer;\n\nvarying float ratio;\nvarying vec3 pickingColor;\n\nvoid main(void) {\n vec4 color = vec4(mix(color0 / 255.0, color1 / 255.0, ratio), opacity);\n gl_FragColor = mix(color, vec4(pickingColor / 255., 1.), renderPickingBuffer);\n}\n', | ||
id: 'arc' | ||
@@ -125,15 +138,11 @@ }), | ||
drawMode: 'LINE_STRIP', | ||
vertices: new Float32Array(vertices) | ||
vertices: new Float32Array(positions) | ||
}), | ||
instanced: true, | ||
onBeforeRender: function onBeforeRender() { | ||
var gl = this.program.gl; | ||
this.userData.oldStrokeWidth = gl.getParameter(gl.LINE_WIDTH); | ||
gl.lineWidth(this.userData.strokeWidth || 1); | ||
this.program.gl.lineWidth(this.userData.strokeWidth || 1); | ||
}, | ||
onAfterRender: function onAfterRender() { | ||
var gl = this.program.gl; | ||
gl.lineWidth(this.userData.oldStrokeWidth || 1); | ||
this.program.gl.lineWidth(this.userData.oldStrokeWidth || 1); | ||
} | ||
@@ -145,14 +154,10 @@ }); | ||
value: function updateColors() { | ||
// Get colors from first object | ||
var object = this.getFirstObject(); | ||
if (object) { | ||
this.setUniforms({ | ||
color0: object.colors.c0, | ||
color1: object.colors.c1 | ||
}); | ||
} | ||
this.setUniforms({ | ||
color0: this.props.color0, | ||
color1: this.props.color1 | ||
}); | ||
} | ||
}, { | ||
key: 'calculatePositions', | ||
value: function calculatePositions(attribute) { | ||
key: 'calculateInstancePositions', | ||
value: function calculateInstancePositions(attribute) { | ||
var data = this.props.data; | ||
@@ -198,2 +203,2 @@ var value = attribute.value; | ||
exports.default = ArcLayer; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9sYXllcnMvYXJjLWxheWVyL2FyYy1sYXllci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0FBb0JBOzs7O0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUNBLElBQU0sVUFBVSxRQUFRLFNBQVIsQ0FBaEI7O0FBRUEsSUFBTSxhQUFhO0FBQ2pCLGFBQVcsRUFBQyxNQUFNLENBQVAsRUFBVSxLQUFLLElBQWYsRUFBcUIsS0FBSyxJQUExQixFQUFnQyxLQUFLLElBQXJDLEVBQTJDLEtBQUssSUFBaEQ7QUFETSxDQUFuQjs7SUFJcUIsUTs7Ozs7Ozs7Ozs7QUFRbkIsb0JBQVksSUFBWixFQUFrQjtBQUFBOztBQUFBO0FBRWQsbUJBQWE7QUFGQyxPQUdYLElBSFc7QUFLakI7Ozs7c0NBRWlCO0FBQUEsbUJBQ2UsS0FBSyxLQURwQjtBQUFBLFVBQ1QsRUFEUyxVQUNULEVBRFM7QUFBQSxVQUNMLGdCQURLLFVBQ0wsZ0JBREs7OztBQUdoQixVQUFNLFFBQVEsS0FBSyxXQUFMLENBQWlCLEVBQWpCLENBQWQ7QUFDQSxZQUFNLFFBQU4sQ0FBZSxXQUFmLEdBQTZCLEtBQUssS0FBTCxDQUFXLFdBQXhDO0FBQ0EsV0FBSyxRQUFMLENBQWMsRUFBQyxZQUFELEVBQWQ7O0FBRUEsdUJBQWlCLFlBQWpCLENBQThCLFVBQTlCLEVBQTBDO0FBQ3hDLG1CQUFXLEVBQUMsUUFBUSxLQUFLLGtCQUFkO0FBRDZCLE9BQTFDOztBQUlBLFdBQUssWUFBTDtBQUNEOzs7cUNBRWdCLFEsRUFBVSxTLEVBQVc7O0FBRXBDLDJGQUF1QixRQUF2QixFQUFpQyxTQUFqQztBQUNBLFdBQUssS0FBTCxDQUFXLEtBQVgsQ0FBaUIsUUFBakIsQ0FBMEIsV0FBMUIsR0FBd0MsVUFBVSxXQUFsRDs7QUFFQSxXQUFLLFlBQUw7QUFDRDs7O2dDQUVXLEUsRUFBSTtBQUNkLFVBQUksV0FBVyxFQUFmO0FBQ0EsVUFBTSxlQUFlLEVBQXJCO0FBQ0EsV0FBSyxJQUFJLElBQUksQ0FBYixFQUFnQixJQUFJLFlBQXBCLEVBQWtDLEdBQWxDLEVBQXVDO0FBQ3JDLGdEQUFlLFFBQWYsSUFBeUIsQ0FBekIsRUFBNEIsQ0FBNUIsRUFBK0IsQ0FBL0I7QUFDRDs7QUFFRCxhQUFPLGdCQUFVO0FBQ2YsaUJBQVMsa0JBQVksRUFBWixFQUFnQjtBQUN2Qix3OEZBRHVCO0FBRXZCLHU5Q0FGdUI7QUFHdkIsY0FBSTtBQUhtQixTQUFoQixDQURNO0FBTWYsa0JBQVUsbUJBQWE7QUFDckIsY0FBSSxLQURpQjtBQUVyQixvQkFBVSxZQUZXO0FBR3JCLG9CQUFVLElBQUksWUFBSixDQUFpQixRQUFqQjtBQUhXLFNBQWIsQ0FOSztBQVdmLG1CQUFXLElBWEk7QUFZZixzQkFaZSw0QkFZRTtBQUFBLGNBQ1IsRUFEUSxHQUNGLEtBQUssT0FESCxDQUNSLEVBRFE7O0FBRWYsZUFBSyxRQUFMLENBQWMsY0FBZCxHQUErQixHQUFHLFlBQUgsQ0FBZ0IsR0FBRyxVQUFuQixDQUEvQjtBQUNBLGFBQUcsU0FBSCxDQUFhLEtBQUssUUFBTCxDQUFjLFdBQWQsSUFBNkIsQ0FBMUM7QUFDRCxTQWhCYztBQWlCZixxQkFqQmUsMkJBaUJDO0FBQUEsY0FDUCxFQURPLEdBQ0QsS0FBSyxPQURKLENBQ1AsRUFETzs7QUFFZCxhQUFHLFNBQUgsQ0FBYSxLQUFLLFFBQUwsQ0FBYyxjQUFkLElBQWdDLENBQTdDO0FBQ0Q7QUFwQmMsT0FBVixDQUFQO0FBc0JEOzs7bUNBRWM7O0FBRWIsVUFBTSxTQUFTLEtBQUssY0FBTCxFQUFmO0FBQ0EsVUFBSSxNQUFKLEVBQVk7QUFDVixhQUFLLFdBQUwsQ0FBaUI7QUFDZixrQkFBUSxPQUFPLE1BQVAsQ0FBYyxFQURQO0FBRWYsa0JBQVEsT0FBTyxNQUFQLENBQWM7QUFGUCxTQUFqQjtBQUlEO0FBQ0Y7Ozt1Q0FFa0IsUyxFQUFXO0FBQUEsVUFDckIsSUFEcUIsR0FDYixLQUFLLEtBRFEsQ0FDckIsSUFEcUI7QUFBQSxVQUVyQixLQUZxQixHQUVOLFNBRk0sQ0FFckIsS0FGcUI7QUFBQSxVQUVkLElBRmMsR0FFTixTQUZNLENBRWQsSUFGYzs7QUFHNUIsVUFBSSxJQUFJLENBQVI7QUFINEI7QUFBQTtBQUFBOztBQUFBO0FBSTVCLDZCQUFrQixJQUFsQiw4SEFBd0I7QUFBQSxjQUFiLEdBQWE7O0FBQ3RCLGdCQUFNLElBQUksQ0FBVixJQUFlLElBQUksUUFBSixDQUFhLEVBQTVCO0FBQ0EsZ0JBQU0sSUFBSSxDQUFWLElBQWUsSUFBSSxRQUFKLENBQWEsRUFBNUI7QUFDQSxnQkFBTSxJQUFJLENBQVYsSUFBZSxJQUFJLFFBQUosQ0FBYSxFQUE1QjtBQUNBLGdCQUFNLElBQUksQ0FBVixJQUFlLElBQUksUUFBSixDQUFhLEVBQTVCO0FBQ0EsZUFBSyxJQUFMO0FBQ0Q7QUFWMkI7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQVc3Qjs7Ozs7O2tCQTFGa0IsUSIsImZpbGUiOiJhcmMtbGF5ZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIDIwMTUgVWJlciBUZWNobm9sb2dpZXMsIEluYy5cbi8vXG4vLyBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4vLyBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4vLyBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4vLyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4vLyBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbi8vIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4vL1xuLy8gVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW5cbi8vIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuLy9cbi8vIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1Jcbi8vIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuLy8gRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4vLyBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4vLyBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuLy8gT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTlxuLy8gVEhFIFNPRlRXQVJFLlxuXG5pbXBvcnQgTGF5ZXIgZnJvbSAnLi4vLi4vbGF5ZXInO1xuaW1wb3J0IHtNb2RlbCwgUHJvZ3JhbSwgR2VvbWV0cnl9IGZyb20gJ2x1bWEuZ2wnO1xuY29uc3QgZ2xzbGlmeSA9IHJlcXVpcmUoJ2dsc2xpZnknKTtcblxuY29uc3QgQVRUUklCVVRFUyA9IHtcbiAgcG9zaXRpb25zOiB7c2l6ZTogNCwgJzAnOiAneDAnLCAnMSc6ICd5MCcsICcyJzogJ3gxJywgJzMnOiAneTEnfVxufTtcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQXJjTGF5ZXIgZXh0ZW5kcyBMYXllciB7XG4gIC8qKlxuICAgKiBAY2xhc3NkZXNjXG4gICAqIEFyY0xheWVyXG4gICAqXG4gICAqIEBjbGFzc1xuICAgKiBAcGFyYW0ge29iamVjdH0gb3B0c1xuICAgKi9cbiAgY29uc3RydWN0b3Iob3B0cykge1xuICAgIHN1cGVyKHtcbiAgICAgIHN0cm9rZVdpZHRoOiAxLFxuICAgICAgLi4ub3B0c1xuICAgIH0pO1xuICB9XG5cbiAgaW5pdGlhbGl6ZVN0YXRlKCkge1xuICAgIGNvbnN0IHtnbCwgYXR0cmlidXRlTWFuYWdlcn0gPSB0aGlzLnN0YXRlO1xuXG4gICAgY29uc3QgbW9kZWwgPSB0aGlzLmNyZWF0ZU1vZGVsKGdsKTtcbiAgICBtb2RlbC51c2VyRGF0YS5zdHJva2VXaWR0aCA9IHRoaXMucHJvcHMuc3Ryb2tlV2lkdGg7XG4gICAgdGhpcy5zZXRTdGF0ZSh7bW9kZWx9KTtcblxuICAgIGF0dHJpYnV0ZU1hbmFnZXIuYWRkSW5zdGFuY2VkKEFUVFJJQlVURVMsIHtcbiAgICAgIHBvc2l0aW9uczoge3VwZGF0ZTogdGhpcy5jYWxjdWxhdGVQb3NpdGlvbnN9XG4gICAgfSk7XG5cbiAgICB0aGlzLnVwZGF0ZUNvbG9ycygpO1xuICB9XG5cbiAgd2lsbFJlY2VpdmVQcm9wcyhvbGRQcm9wcywgbmV4dFByb3BzKSB7XG5cbiAgICBzdXBlci53aWxsUmVjZWl2ZVByb3BzKG9sZFByb3BzLCBuZXh0UHJvcHMpO1xuICAgIHRoaXMuc3RhdGUubW9kZWwudXNlckRhdGEuc3Ryb2tlV2lkdGggPSBuZXh0UHJvcHMuc3Ryb2tlV2lkdGg7XG5cbiAgICB0aGlzLnVwZGF0ZUNvbG9ycygpO1xuICB9XG5cbiAgY3JlYXRlTW9kZWwoZ2wpIHtcbiAgICBsZXQgdmVydGljZXMgPSBbXTtcbiAgICBjb25zdCBOVU1fU0VHTUVOVFMgPSA1MDtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IE5VTV9TRUdNRU5UUzsgaSsrKSB7XG4gICAgICB2ZXJ0aWNlcyA9IFsuLi52ZXJ0aWNlcywgaSwgaSwgaV07XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBNb2RlbCh7XG4gICAgICBwcm9ncmFtOiBuZXcgUHJvZ3JhbShnbCwge1xuICAgICAgICB2czogZ2xzbGlmeSgnLi9hcmMtbGF5ZXItdmVydGV4Lmdsc2wnKSxcbiAgICAgICAgZnM6IGdsc2xpZnkoJy4vYXJjLWxheWVyLWZyYWdtZW50Lmdsc2wnKSxcbiAgICAgICAgaWQ6ICdhcmMnXG4gICAgICB9KSxcbiAgICAgIGdlb21ldHJ5OiBuZXcgR2VvbWV0cnkoe1xuICAgICAgICBpZDogJ2FyYycsXG4gICAgICAgIGRyYXdNb2RlOiAnTElORV9TVFJJUCcsXG4gICAgICAgIHZlcnRpY2VzOiBuZXcgRmxvYXQzMkFycmF5KHZlcnRpY2VzKVxuICAgICAgfSksXG4gICAgICBpbnN0YW5jZWQ6IHRydWUsXG4gICAgICBvbkJlZm9yZVJlbmRlcigpIHtcbiAgICAgICAgY29uc3Qge2dsfSA9IHRoaXMucHJvZ3JhbTtcbiAgICAgICAgdGhpcy51c2VyRGF0YS5vbGRTdHJva2VXaWR0aCA9IGdsLmdldFBhcmFtZXRlcihnbC5MSU5FX1dJRFRIKTtcbiAgICAgICAgZ2wubGluZVdpZHRoKHRoaXMudXNlckRhdGEuc3Ryb2tlV2lkdGggfHwgMSk7XG4gICAgICB9LFxuICAgICAgb25BZnRlclJlbmRlcigpIHtcbiAgICAgICAgY29uc3Qge2dsfSA9IHRoaXMucHJvZ3JhbTtcbiAgICAgICAgZ2wubGluZVdpZHRoKHRoaXMudXNlckRhdGEub2xkU3Ryb2tlV2lkdGggfHwgMSk7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICB1cGRhdGVDb2xvcnMoKSB7XG4gICAgLy8gR2V0IGNvbG9ycyBmcm9tIGZpcnN0IG9iamVjdFxuICAgIGNvbnN0IG9iamVjdCA9IHRoaXMuZ2V0Rmlyc3RPYmplY3QoKTtcbiAgICBpZiAob2JqZWN0KSB7XG4gICAgICB0aGlzLnNldFVuaWZvcm1zKHtcbiAgICAgICAgY29sb3IwOiBvYmplY3QuY29sb3JzLmMwLFxuICAgICAgICBjb2xvcjE6IG9iamVjdC5jb2xvcnMuYzFcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIGNhbGN1bGF0ZVBvc2l0aW9ucyhhdHRyaWJ1dGUpIHtcbiAgICBjb25zdCB7ZGF0YX0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IHt2YWx1ZSwgc2l6ZX0gPSBhdHRyaWJ1dGU7XG4gICAgbGV0IGkgPSAwO1xuICAgIGZvciAoY29uc3QgYXJjIG9mIGRhdGEpIHtcbiAgICAgIHZhbHVlW2kgKyAwXSA9IGFyYy5wb3NpdGlvbi54MDtcbiAgICAgIHZhbHVlW2kgKyAxXSA9IGFyYy5wb3NpdGlvbi55MDtcbiAgICAgIHZhbHVlW2kgKyAyXSA9IGFyYy5wb3NpdGlvbi54MTtcbiAgICAgIHZhbHVlW2kgKyAzXSA9IGFyYy5wb3NpdGlvbi55MTtcbiAgICAgIGkgKz0gc2l6ZTtcbiAgICB9XG4gIH1cblxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/layers/arc-layer/arc-layer.js"],"names":[],"mappings":"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","file":"arc-layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport Layer from '../../layer';\nimport {Model, Program, Geometry} from 'luma.gl';\nconst glslify = require('glslify');\n\nconst ATTRIBUTES = {\n  instancePositions: {size: 4, '0': 'x0', '1': 'y0', '2': 'x1', '3': 'y1'}\n};\n\nexport default class ArcLayer extends Layer {\n  /**\n   * @classdesc\n   * ArcLayer\n   *\n   * @class\n   * @param {object} opts\n   */\n  constructor({\n    strokeWidth = 1,\n    color0 = [255, 0, 0],\n    color1 = [0, 0, 255],\n    ...opts\n  } = {}) {\n    super({\n      strokeWidth,\n      color0,\n      color1,\n      ...opts\n    });\n  }\n\n  initializeState() {\n    const {gl, attributeManager} = this.state;\n\n    const model = this.createModel(gl);\n    model.userData.strokeWidth = this.props.strokeWidth;\n    this.setState({model});\n\n    attributeManager.addInstanced(ATTRIBUTES, {\n      instancePositions: {update: this.calculateInstancePositions}\n    });\n\n    this.updateColors();\n  }\n\n  willReceiveProps(oldProps, nextProps) {\n    super.willReceiveProps(oldProps, nextProps);\n    this.state.model.userData.strokeWidth = nextProps.strokeWidth;\n    this.updateColors();\n  }\n\n  createModel(gl) {\n    let positions = [];\n    const NUM_SEGMENTS = 50;\n    for (let i = 0; i < NUM_SEGMENTS; i++) {\n      positions = [...positions, i, i, i];\n    }\n\n    return new Model({\n      program: new Program(gl, {\n        vs: glslify('./arc-layer-vertex.glsl'),\n        fs: glslify('./arc-layer-fragment.glsl'),\n        id: 'arc'\n      }),\n      geometry: new Geometry({\n        id: 'arc',\n        drawMode: 'LINE_STRIP',\n        vertices: new Float32Array(positions)\n      }),\n      instanced: true,\n      onBeforeRender() {\n        this.userData.oldStrokeWidth = gl.getParameter(gl.LINE_WIDTH);\n        this.program.gl.lineWidth(this.userData.strokeWidth || 1);\n      },\n      onAfterRender() {\n        this.program.gl.lineWidth(this.userData.oldStrokeWidth || 1);\n      }\n    });\n  }\n\n  updateColors() {\n    this.setUniforms({\n      color0: this.props.color0,\n      color1: this.props.color1\n    });\n  }\n\n  calculateInstancePositions(attribute) {\n    const {data} = this.props;\n    const {value, size} = attribute;\n    let i = 0;\n    for (const arc of data) {\n      value[i + 0] = arc.position.x0;\n      value[i + 1] = arc.position.y0;\n      value[i + 2] = arc.position.x1;\n      value[i + 3] = arc.position.y1;\n      i += size;\n    }\n  }\n\n}\n"]} |
@@ -63,4 +63,4 @@ 'use strict'; | ||
var ATTRIBUTES = { | ||
vertices: { size: 3, '0': 'x', '1': 'y', '2': 'unused' }, | ||
indices: { size: 1, '0': 'index' }, | ||
positions: { size: 3, '0': 'x', '1': 'y', '2': 'unused' }, | ||
colors: { size: 3, '0': 'red', '1': 'green', '2': 'blue' }, | ||
@@ -106,3 +106,3 @@ // Override picking colors to prevent auto allocation | ||
indices: { update: this.calculateIndices }, | ||
vertices: { update: this.calculateVertices }, | ||
positions: { update: this.calculatePositions }, | ||
colors: { update: this.calculateColors }, | ||
@@ -145,3 +145,3 @@ // Instanced attributes | ||
program: new _luma.Program(gl, { | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* vertex shader for the choropleth-layer */\n#define SHADER_NAME choropleth-layer-vertex-shader\n\n// viewport: [x, y, width, height]\nconst float TILE_SIZE_1540259130 = 512.0;\nconst float PI = 3.1415926536;\n\n// non-linear projection: lnglats => zoom level depdendent projected coords\nvec2 mercatorProject(vec2 lnglat, float zoom) {\n // Note: Could be precomputed, at the expense of less simple API\n float scale = pow(2.0, zoom) * TILE_SIZE_1540259130 / (PI * 2.0);\n\n float longitude = lnglat.x;\n float latitude = lnglat.y;\n\n float lamda = radians(longitude);\n float phi = radians(latitude);\n\n float x = scale * (lamda + PI);\n float y = scale * (PI - log(tan(PI * 0.25 + phi * 0.5)));\n\n return vec2(x, y);\n}\n\nuniform float mercatorZoom;\n\nattribute vec3 vertices;\nattribute vec3 colors;\nattribute vec3 pickingColors;\n\nuniform mat4 projectionMatrix;\nuniform mat4 worldMatrix;\n\nuniform float opacity;\nuniform float renderPickingBuffer;\nuniform vec3 selectedPickingColor;\n\nvarying vec4 vColor;\n\nvoid main(void) {\n vec2 pos = mercatorProject(vertices.xy, mercatorZoom);\n vec3 p = vec3(pos.xy, vertices.z);\n gl_Position = projectionMatrix * worldMatrix * vec4(p, 1.0);\n\n float alpha = pickingColors == selectedPickingColor ? 0.5 : opacity;\n vColor = vec4(mix(colors / 255., pickingColors / 255., renderPickingBuffer), alpha);\n}\n', | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* vertex shader for the choropleth-layer */\n#define SHADER_NAME choropleth-layer-vertex-shader\n\n// viewport: [x, y, width, height]\nconst float TILE_SIZE_1540259130 = 512.0;\nconst float PI = 3.1415926536;\n\n// non-linear projection: lnglats => zoom level depdendent projected coords\nvec2 mercatorProject(vec2 lnglat, float zoom) {\n // Note: Could be precomputed, at the expense of less simple API\n float scale = pow(2.0, zoom) * TILE_SIZE_1540259130 / (PI * 2.0);\n\n float longitude = lnglat.x;\n float latitude = lnglat.y;\n\n float lamda = radians(longitude);\n float phi = radians(latitude);\n\n float x = scale * (lamda + PI);\n float y = scale * (PI - log(tan(PI * 0.25 + phi * 0.5)));\n\n return vec2(x, y);\n}\n\nuniform float mercatorZoom;\n\nattribute vec3 positions;\nattribute vec3 colors;\nattribute vec3 pickingColors;\n\nuniform mat4 projectionMatrix;\nuniform mat4 worldMatrix;\n\nuniform float opacity;\nuniform float renderPickingBuffer;\nuniform vec3 selectedPickingColor;\n\nvarying vec4 vColor;\n\nvec4 getColor(vec4 color, float opacity, vec3 pickingColor, float renderPickingBuffer) {\n vec4 color4 = vec4(color.xyz / 255., color.w / 255. * opacity);\n vec4 pickingColor4 = vec4(pickingColor / 255., 1.);\n return mix(color4, pickingColor4, renderPickingBuffer);\n}\n\nvoid main(void) {\n vec2 pos = mercatorProject(positions.xy, mercatorZoom);\n vec3 p = vec3(pos.xy, positions.z);\n gl_Position = projectionMatrix * worldMatrix * vec4(p, 1.);\n\n vec4 color = vec4(colors / 255., opacity);\n vec4 pickingColor = vec4(pickingColors / 255., 1.);\n vColor = mix(color, pickingColor, renderPickingBuffer);\n\n // float alpha = pickingColors == selectedPickingColor ? 0.5 : opacity;\n // vColor = vec4(mix(colors / 255., pickingColors / 255., renderPickingBuffer), alpha);\n}\n', | ||
fs: '// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* fragment shader for the choropleth-layer */\n\n#ifdef GL_ES\nprecision highp float;\n#define GLSLIFY 1\n#endif\n\nvarying vec4 vColor;\n\nvoid main(void) {\n gl_FragColor = vColor;\n}\n', | ||
@@ -159,4 +159,4 @@ id: 'choropleth' | ||
}, { | ||
key: 'calculateVertices', | ||
value: function calculateVertices(attribute) { | ||
key: 'calculatePositions', | ||
value: function calculatePositions(attribute) { | ||
var vertices = (0, _lodash2.default)(this.state.groupedVertices); | ||
@@ -281,2 +281,2 @@ attribute.value = new Float32Array(vertices); | ||
exports.default = ChoroplethLayer; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/layers/choropleth-layer/choropleth-layer.js"],"names":[],"mappings":"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","file":"choropleth-layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport Layer from '../../layer';\nimport earcut from 'earcut';\nimport flattenDeep from 'lodash.flattendeep';\nimport normalize from 'geojson-normalize';\nimport {Model, Program, Geometry} from 'luma.gl';\nconst glslify = require('glslify');\n\nconst ATTRIBUTES = {\n  vertices: {size: 3, '0': 'x', '1': 'y', '2': 'unused'},\n  indices: {size: 1, '0': 'index'},\n  colors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'},\n  // Override picking colors to prevent auto allocation\n  pickingColors: {size: 3, '0': 'pickRed', '1': 'pickGreen', '2': 'pickBlue'}\n};\n\nexport default class ChoroplethLayer extends Layer {\n  /**\n   * @classdesc\n   * ChoroplethLayer\n   *\n   * @class\n   * @param {object} props\n   * @param {bool} props.drawContour - ? drawContour : drawArea\n   * @param {function} props.onChoroplethHovered - provide proerties of the\n   * selected choropleth, together with the mouse event when mouse hovered\n   * @param {function} props.onChoroplethClicked - provide proerties of the\n   * selected choropleth, together with the mouse event when mouse clicked\n   */\n  constructor(props) {\n    super({\n      opacity: 1,\n      ...props\n    });\n  }\n\n  initializeState() {\n    const {gl, attributeManager} = this.state;\n\n    attributeManager.addDynamic(ATTRIBUTES, {\n      // Primtive attributes\n      indices: {update: this.calculateIndices},\n      vertices: {update: this.calculateVertices},\n      colors: {update: this.calculateColors},\n      // Instanced attributes\n      pickingColors: {update: this.calculatePickingColors, noAlloc: true}\n    });\n\n    this.setUniforms({opacity: this.props.opacity});\n    this.setState({\n      numInstances: 0,\n      model: this.getModel(gl)\n    });\n\n    this.extractChoropleths();\n  }\n\n  willReceiveProps(oldProps, newProps) {\n    super.willReceiveProps(oldProps, newProps);\n\n    const {dataChanged, attributeManager} = this.state;\n    if (dataChanged) {\n      this.extractChoropleths();\n\n      attributeManager.invalidateAll();\n    }\n\n    if (oldProps.opacity !== newProps.opacity) {\n      this.setUniforms({opacity: newProps.opacity});\n    }\n  }\n\n  getModel(gl) {\n    return new Model({\n      program: new Program(gl, {\n        vs: glslify('./choropleth-layer-vertex.glsl'),\n        fs: glslify('./choropleth-layer-fragment.glsl'),\n        id: 'choropleth'\n      }),\n      geometry: new Geometry({\n        id: this.props.id,\n        drawMode: this.props.drawContour ? 'LINES' : 'TRIANGLES'\n      }),\n      vertexCount: 0,\n      isIndexed: true\n    });\n  }\n\n  calculateVertices(attribute) {\n    const vertices = flattenDeep(this.state.groupedVertices);\n    attribute.value = new Float32Array(vertices);\n  }\n\n  calculateIndices(attribute) {\n    // adjust index offset for multiple choropleths\n    const offsets = this.state.groupedVertices.reduce(\n      (acc, vertices) => [...acc, acc[acc.length - 1] + vertices.length],\n      [0]\n    );\n\n    const indices = this.state.groupedVertices.map(\n      (vertices, choroplethIndex) => this.props.drawContour ?\n        // 1. get sequentially ordered indices of each choropleth contour\n        // 2. offset them by the number of indices in previous choropleths\n        this.calculateContourIndices(vertices.length).map(\n          index => index + offsets[choroplethIndex]\n        ) :\n        // 1. get triangulated indices for the internal areas\n        // 2. offset them by the number of indices in previous choropleths\n        earcut(flattenDeep(vertices), null, 3).map(\n          index => index + offsets[choroplethIndex]\n        )\n    );\n\n    attribute.value = new Uint16Array(flattenDeep(indices));\n    attribute.bufferType = this.state.gl.ELEMENT_ARRAY_BUFFER;\n    this.state.model.setVertexCount(attribute.value.length / attribute.size);\n  }\n\n  calculateColors(attribute) {\n    const colors = this.state.groupedVertices.map(\n      vertices => vertices.map(\n        vertex => this.props.drawContour ? [0, 0, 0] : [128, 128, 128]\n      )\n    );\n\n    attribute.value = new Float32Array(flattenDeep(colors));\n  }\n\n  // Override the default picking colors calculation\n  calculatePickingColors(attribute) {\n    const colors = this.state.groupedVertices.map(\n      (vertices, choroplethIndex) => vertices.map(\n        vertex => this.props.drawContour ? [-1, -1, -1] : [\n          (choroplethIndex + 1) % 256,\n          Math.floor((choroplethIndex + 1) / 256) % 256,\n          Math.floor((choroplethIndex + 1) / 256 / 256) % 256]\n      )\n    );\n\n    attribute.value = new Float32Array(flattenDeep(colors));\n  }\n\n  extractChoropleths() {\n    const {data} = this.props;\n    const normalizedGeojson = normalize(data);\n\n    this.state.choropleths = normalizedGeojson.features.map(choropleth => {\n      let coordinates = choropleth.geometry.coordinates[0];\n      // flatten nested polygons\n      if (coordinates.length === 1 && coordinates[0].length > 2) {\n        coordinates = coordinates[0];\n      }\n      return {\n        properties: choropleth.properties,\n        coordinates\n      };\n    });\n\n    this.state.groupedVertices = this.state.choropleths.map(\n      choropleth => choropleth.coordinates.map(\n        coordinate => [coordinate[0], coordinate[1], 0]\n      )\n    );\n  }\n\n  calculateContourIndices(numVertices) {\n    // use vertex pairs for gl.LINES => [0, 1, 1, 2, 2, ..., n-1, n-1, 0]\n    let indices = [];\n    for (let i = 1; i < numVertices - 1; i++) {\n      indices = [...indices, i, i];\n    }\n    return [0, ...indices, 0];\n\n  }\n\n  onHover(info) {\n    const {index} = info;\n    const {data} = this.props;\n    const feature = data.features[index];\n    this.props.onHover({...info, feature});\n  }\n\n  onClick(info) {\n    const {index} = info;\n    const {data} = this.props;\n    const feature = data.features[index];\n    this.props.onClick({...info, feature});\n  }\n\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/layers/choropleth-layer/choropleth-layer.js"],"names":[],"mappings":"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","file":"choropleth-layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport Layer from '../../layer';\nimport earcut from 'earcut';\nimport flattenDeep from 'lodash.flattendeep';\nimport normalize from 'geojson-normalize';\nimport {Model, Program, Geometry} from 'luma.gl';\nconst glslify = require('glslify');\n\nconst ATTRIBUTES = {\n  indices: {size: 1, '0': 'index'},\n  positions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'},\n  colors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'},\n  // Override picking colors to prevent auto allocation\n  pickingColors: {size: 3, '0': 'pickRed', '1': 'pickGreen', '2': 'pickBlue'}\n};\n\nexport default class ChoroplethLayer extends Layer {\n  /**\n   * @classdesc\n   * ChoroplethLayer\n   *\n   * @class\n   * @param {object} props\n   * @param {bool} props.drawContour - ? drawContour : drawArea\n   * @param {function} props.onChoroplethHovered - provide proerties of the\n   * selected choropleth, together with the mouse event when mouse hovered\n   * @param {function} props.onChoroplethClicked - provide proerties of the\n   * selected choropleth, together with the mouse event when mouse clicked\n   */\n  constructor(props) {\n    super({\n      opacity: 1,\n      ...props\n    });\n  }\n\n  initializeState() {\n    const {gl, attributeManager} = this.state;\n\n    attributeManager.addDynamic(ATTRIBUTES, {\n      // Primtive attributes\n      indices: {update: this.calculateIndices},\n      positions: {update: this.calculatePositions},\n      colors: {update: this.calculateColors},\n      // Instanced attributes\n      pickingColors: {update: this.calculatePickingColors, noAlloc: true}\n    });\n\n    this.setUniforms({opacity: this.props.opacity});\n    this.setState({\n      numInstances: 0,\n      model: this.getModel(gl)\n    });\n\n    this.extractChoropleths();\n  }\n\n  willReceiveProps(oldProps, newProps) {\n    super.willReceiveProps(oldProps, newProps);\n\n    const {dataChanged, attributeManager} = this.state;\n    if (dataChanged) {\n      this.extractChoropleths();\n\n      attributeManager.invalidateAll();\n    }\n\n    if (oldProps.opacity !== newProps.opacity) {\n      this.setUniforms({opacity: newProps.opacity});\n    }\n  }\n\n  getModel(gl) {\n    return new Model({\n      program: new Program(gl, {\n        vs: glslify('./choropleth-layer-vertex.glsl'),\n        fs: glslify('./choropleth-layer-fragment.glsl'),\n        id: 'choropleth'\n      }),\n      geometry: new Geometry({\n        id: this.props.id,\n        drawMode: this.props.drawContour ? 'LINES' : 'TRIANGLES'\n      }),\n      vertexCount: 0,\n      isIndexed: true\n    });\n  }\n\n  calculatePositions(attribute) {\n    const vertices = flattenDeep(this.state.groupedVertices);\n    attribute.value = new Float32Array(vertices);\n  }\n\n  calculateIndices(attribute) {\n    // adjust index offset for multiple choropleths\n    const offsets = this.state.groupedVertices.reduce(\n      (acc, vertices) => [...acc, acc[acc.length - 1] + vertices.length],\n      [0]\n    );\n\n    const indices = this.state.groupedVertices.map(\n      (vertices, choroplethIndex) => this.props.drawContour ?\n        // 1. get sequentially ordered indices of each choropleth contour\n        // 2. offset them by the number of indices in previous choropleths\n        this.calculateContourIndices(vertices.length).map(\n          index => index + offsets[choroplethIndex]\n        ) :\n        // 1. get triangulated indices for the internal areas\n        // 2. offset them by the number of indices in previous choropleths\n        earcut(flattenDeep(vertices), null, 3).map(\n          index => index + offsets[choroplethIndex]\n        )\n    );\n\n    attribute.value = new Uint16Array(flattenDeep(indices));\n    attribute.bufferType = this.state.gl.ELEMENT_ARRAY_BUFFER;\n    this.state.model.setVertexCount(attribute.value.length / attribute.size);\n  }\n\n  calculateColors(attribute) {\n    const colors = this.state.groupedVertices.map(\n      vertices => vertices.map(\n        vertex => this.props.drawContour ? [0, 0, 0] : [128, 128, 128]\n      )\n    );\n\n    attribute.value = new Float32Array(flattenDeep(colors));\n  }\n\n  // Override the default picking colors calculation\n  calculatePickingColors(attribute) {\n    const colors = this.state.groupedVertices.map(\n      (vertices, choroplethIndex) => vertices.map(\n        vertex => this.props.drawContour ? [-1, -1, -1] : [\n          (choroplethIndex + 1) % 256,\n          Math.floor((choroplethIndex + 1) / 256) % 256,\n          Math.floor((choroplethIndex + 1) / 256 / 256) % 256]\n      )\n    );\n\n    attribute.value = new Float32Array(flattenDeep(colors));\n  }\n\n  extractChoropleths() {\n    const {data} = this.props;\n    const normalizedGeojson = normalize(data);\n\n    this.state.choropleths = normalizedGeojson.features.map(choropleth => {\n      let coordinates = choropleth.geometry.coordinates[0];\n      // flatten nested polygons\n      if (coordinates.length === 1 && coordinates[0].length > 2) {\n        coordinates = coordinates[0];\n      }\n      return {\n        properties: choropleth.properties,\n        coordinates\n      };\n    });\n\n    this.state.groupedVertices = this.state.choropleths.map(\n      choropleth => choropleth.coordinates.map(\n        coordinate => [coordinate[0], coordinate[1], 0]\n      )\n    );\n  }\n\n  calculateContourIndices(numVertices) {\n    // use vertex pairs for gl.LINES => [0, 1, 1, 2, 2, ..., n-1, n-1, 0]\n    let indices = [];\n    for (let i = 1; i < numVertices - 1; i++) {\n      indices = [...indices, i, i];\n    }\n    return [0, ...indices, 0];\n\n  }\n\n  onHover(info) {\n    const {index} = info;\n    const {data} = this.props;\n    const feature = data.features[index];\n    this.props.onHover({...info, feature});\n  }\n\n  onClick(info) {\n    const {index} = info;\n    const {data} = this.props;\n    const feature = data.features[index];\n    this.props.onClick({...info, feature});\n  }\n\n}\n"]} |
@@ -51,4 +51,4 @@ 'use strict'; | ||
var ATTRIBUTES = { | ||
positions: { size: 3, '0': 'x', '1': 'y', '2': 'unused' }, | ||
colors: { size: 4, '0': 'red', '1': 'green', '2': 'blue', '3': 'alpha' } | ||
instancePositions: { size: 3, '0': 'x', '1': 'y', '2': 'unused' }, | ||
instanceColors: { size: 4, '0': 'red', '1': 'green', '2': 'blue', '3': 'alpha' } | ||
}; | ||
@@ -99,4 +99,4 @@ | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
positions: { update: this.calculatePositions }, | ||
colors: { update: this.calculateColors } | ||
instancePositions: { update: this.calculateInstancePositions }, | ||
instanceColors: { update: this.calculateInstanceColors } | ||
}); | ||
@@ -122,3 +122,3 @@ | ||
program: new _luma.Program(gl, { | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* vertex shader for the grid-layer */\n#define SHADER_NAME grid-layer-vs\n\nattribute vec3 vertices;\nattribute vec3 positions;\nattribute vec4 colors;\nattribute vec3 pickingColors;\n\nuniform float maxCount;\nuniform float opacity;\nuniform float renderPickingBuffer;\nuniform vec3 scale;\nuniform vec3 selectedPickingColor;\n\nuniform mat4 worldMatrix;\nuniform mat4 projectionMatrix;\n\nvarying vec4 vColor;\n\nvoid main(void) {\n float alpha = pickingColors == selectedPickingColor ? 1.5 * colors.w : colors.w;\n vColor = vec4(mix(colors.xyz / maxCount, pickingColors / 255., renderPickingBuffer), alpha);\n\n vec3 p = positions + vertices * scale;\n gl_Position = projectionMatrix * worldMatrix * vec4(p, 1.0);\n}\n', | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* vertex shader for the grid-layer */\n#define SHADER_NAME grid-layer-vs\n\nattribute vec3 vertices;\nattribute vec3 instancePositions;\nattribute vec4 instanceColors;\nattribute vec3 instancePickingColors;\n\nuniform float maxCount;\nuniform float opacity;\nuniform float renderPickingBuffer;\nuniform vec3 scale;\nuniform vec3 selectedPickingColor;\n\nuniform mat4 worldMatrix;\nuniform mat4 projectionMatrix;\n\nvarying vec4 vColor;\n\nvoid main(void) {\n float alpha = instancePickingColors == selectedPickingColor ? 1.5 * instanceColors.w : instanceColors.w;\n vColor = vec4(mix(instanceColors.xyz / maxCount, instancePickingColors / 255., renderPickingBuffer), alpha);\n\n vec3 p = instancePositions + vertices * scale;\n gl_Position = projectionMatrix * worldMatrix * vec4(p, 1.0);\n}\n', | ||
fs: '// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* fragment shader for the grid-layer */\n#define SHADER_NAME grid-layer-fs\n\n#ifdef GL_ES\nprecision highp float;\n#define GLSLIFY 1\n#endif\n\nvarying vec4 vColor;\n\nvoid main(void) {\n gl_FragColor = vColor;\n}\n', | ||
@@ -162,4 +162,4 @@ id: 'grid' | ||
}, { | ||
key: 'calculatePositions', | ||
value: function calculatePositions(attribute, numInstances) { | ||
key: 'calculateInstancePositions', | ||
value: function calculateInstancePositions(attribute, numInstances) { | ||
var _props2 = this.props; | ||
@@ -184,4 +184,4 @@ var unitWidth = _props2.unitWidth; | ||
}, { | ||
key: 'calculateColors', | ||
value: function calculateColors(attribute) { | ||
key: 'calculateInstanceColors', | ||
value: function calculateInstanceColors(attribute) { | ||
var _props3 = this.props; | ||
@@ -243,2 +243,2 @@ var data = _props3.data; | ||
exports.default = GridLayer; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/layers/grid-layer/grid-layer.js"],"names":[],"mappings":";;;;;;;;;;;;;AAoBA;;;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,IAAM,UAAU,QAAQ,SAAR,CAAhB;;AAEA,IAAM,aAAa;AACjB,aAAW,EAAC,MAAM,CAAP,EAAU,KAAK,GAAf,EAAoB,KAAK,GAAzB,EAA8B,KAAK,QAAnC,EADM;AAEjB,UAAQ,EAAC,MAAM,CAAP,EAAU,KAAK,KAAf,EAAsB,KAAK,OAA3B,EAAoC,KAAK,MAAzC,EAAiD,KAAK,OAAtD;AAFS,CAAnB;;IAKqB,S;;;;;wBAEK;AACtB,aAAO,UAAP;AACD;;;;;;;;;;;;;;AAWD,qBAAY,IAAZ,EAAkB;AAAA;;AAAA;AAEd,iBAAW,GAFG;AAGd,kBAAY;AAHE,OAIX,IAJW;AAMjB;;;;sCAEiB;AAAA,mBACe,KAAK,KADpB;AAAA,UACT,EADS,UACT,EADS;AAAA,UACL,gBADK,UACL,gBADK;;;AAGhB,WAAK,QAAL,CAAc;AACZ,eAAO,KAAK,QAAL,CAAc,EAAd;AADK,OAAd;;AAIA,uBAAiB,YAAjB,CAA8B,UAA9B,EAA0C;AACxC,mBAAW,EAAC,QAAQ,KAAK,kBAAd,EAD6B;AAExC,gBAAQ,EAAC,QAAQ,KAAK,eAAd;AAFgC,OAA1C;;AAKA,WAAK,UAAL;AACD;;;qCAEgB,Q,EAAU,Q,EAAU;AACnC,4FAAuB,QAAvB,EAAiC,QAAjC;;AAEA,UAAM,kBACJ,SAAS,SAAT,KAAuB,SAAS,SAAhC,IACA,SAAS,UAAT,KAAwB,SAAS,UAFnC;;AAIA,UAAI,mBAAmB,KAAK,KAAL,CAAW,eAAlC,EAAmD;AACjD,aAAK,UAAL;AACD;AACF;;;6BAEQ,E,EAAI;AACX,aAAO,gBAAU;AACf,iBAAS,kBAAY,EAAZ,EAAgB;AACvB,+2DADuB;AAEvB,g2CAFuB;AAGvB,cAAI;AAHmB,SAAhB,CADM;AAMf,kBAAU,mBAAa;AACrB,cAAI,KAAK,KAAL,CAAW,EADM;AAErB,oBAAU,cAFW;AAGrB,oBAAU,IAAI,YAAJ,CAAiB,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,EAAsB,CAAtB,EAAyB,CAAzB,EAA4B,CAA5B,EAA+B,CAA/B,EAAkC,CAAlC,CAAjB;AAHW,SAAb,CANK;AAWf,mBAAW;AAXI,OAAV,CAAP;AAaD;;;iCAEY;AAAA,mBACoC,KAAK,KADzC;AAAA,UACJ,KADI,UACJ,KADI;AAAA,UACG,MADH,UACG,MADH;AAAA,UACW,SADX,UACW,SADX;AAAA,UACsB,UADtB,UACsB,UADtB;;;AAGX,UAAM,SAAS,KAAK,IAAL,CAAU,QAAQ,CAAR,GAAY,SAAtB,CAAf;AACA,UAAM,SAAS,KAAK,IAAL,CAAU,SAAS,CAAT,GAAa,UAAvB,CAAf;AACA,WAAK,QAAL,CAAc;AACZ,sBADY;AAEZ,sBAFY;AAGZ,sBAAc,SAAS;AAHX,OAAd;;AALW,UAWJ,gBAXI,GAWgB,KAAK,KAXrB,CAWJ,gBAXI;;AAYX,uBAAiB,aAAjB;;AAEA,UAAM,SAAS,CAAf;AACA,UAAM,QAAQ,IAAI,YAAJ,CAAiB,CAC7B,YAAY,SAAS,CADQ,EAE7B,aAAa,SAAS,CAFO,EAG7B,CAH6B,CAAjB,CAAd;AAKA,WAAK,WAAL,CAAiB,EAAC,YAAD,EAAjB;AAED;;;uCAEkB,S,EAAW,Y,EAAc;AAAA,oBACK,KAAK,KADV;AAAA,UACnC,SADmC,WACnC,SADmC;AAAA,UACxB,UADwB,WACxB,UADwB;AAAA,UACZ,KADY,WACZ,KADY;AAAA,UACL,MADK,WACL,MADK;AAAA,UAEnC,MAFmC,GAEzB,KAAK,KAFoB,CAEnC,MAFmC;AAAA,UAGnC,KAHmC,GAGpB,SAHoB,CAGnC,KAHmC;AAAA,UAG5B,IAH4B,GAGpB,SAHoB,CAG5B,IAH4B;;;AAK1C,WAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,YAApB,EAAkC,GAAlC,EAAuC;AACrC,YAAM,IAAI,IAAI,MAAd;AACA,YAAM,IAAI,KAAK,KAAL,CAAW,IAAI,MAAf,CAAV;AACA,cAAM,IAAI,IAAJ,GAAW,CAAjB,IAAsB,IAAI,SAAJ,GAAgB,KAAtC;AACA,cAAM,IAAI,IAAJ,GAAW,CAAjB,IAAsB,IAAI,UAAJ,GAAiB,MAAvC;AACA,cAAM,IAAI,IAAJ,GAAW,CAAjB,IAAsB,CAAtB;AACD;AACF;;;oCAEe,S,EAAW;AAAA,oBAC4B,KAAK,KADjC;AAAA,UAClB,IADkB,WAClB,IADkB;AAAA,UACZ,SADY,WACZ,SADY;AAAA,UACD,UADC,WACD,UADC;AAAA,UACW,KADX,WACW,KADX;AAAA,UACkB,MADlB,WACkB,MADlB;AAAA,oBAEA,KAAK,KAFL;AAAA,UAElB,MAFkB,WAElB,MAFkB;AAAA,UAEV,MAFU,WAEV,MAFU;AAAA,UAGlB,KAHkB,GAGH,SAHG,CAGlB,KAHkB;AAAA,UAGX,IAHW,GAGH,SAHG,CAGX,IAHW;;;AAKzB,YAAM,IAAN,CAAW,GAAX;;AALyB;AAAA;AAAA;;AAAA;AAOzB,6BAAoB,IAApB,8HAA0B;AAAA,cAAf,KAAe;;AACxB,cAAM,QAAQ,KAAK,OAAL,CAAa,CAAC,MAAM,QAAN,CAAe,CAAhB,EAAmB,MAAM,QAAN,CAAe,CAAlC,CAAb,CAAd;AACA,cAAM,QAAQ,KAAK,KAAL,CAAW,CAAC,MAAM,CAAN,GAAU,KAAX,IAAoB,SAA/B,CAAd;AACA,cAAM,QAAQ,KAAK,KAAL,CAAW,CAAC,MAAM,CAAN,GAAU,MAAX,IAAqB,UAAhC,CAAd;AACA,cAAI,QAAQ,MAAR,IAAkB,QAAQ,MAA9B,EAAsC;AACpC,gBAAM,KAAK,CAAC,QAAQ,QAAQ,MAAjB,IAA2B,IAAtC;AACA,kBAAM,KAAK,CAAX,IAAgB,MAAM,KAAK,CAAX,KAAiB,CAAjC;AACA,kBAAM,KAAK,CAAX,KAAiB,CAAjB;AACA,kBAAM,KAAK,CAAX,IAAgB,GAAhB;AACD;AACF;AAjBwB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAmBzB,WAAK,WAAL,CAAiB,EAAC,UAAU,KAAK,GAAL,gCAAY,KAAZ,EAAX,EAAjB;AACD;;;;;;kBA5HkB,S","file":"grid-layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport Layer from '../../layer';\nimport {Model, Program, Geometry} from 'luma.gl';\nconst glslify = require('glslify');\n\nconst ATTRIBUTES = {\n  positions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'},\n  colors: {size: 4, '0': 'red', '1': 'green', '2': 'blue', '3': 'alpha'}\n};\n\nexport default class GridLayer extends Layer {\n\n  static get attributes() {\n    return ATTRIBUTES;\n  }\n\n  /**\n   * @classdesc\n   * GridLayer\n   *\n   * @class\n   * @param {object} opts\n   * @param {number} opts.unitWidth - width of the unit rectangle\n   * @param {number} opts.unitHeight - height of the unit rectangle\n   */\n  constructor(opts) {\n    super({\n      unitWidth: 100,\n      unitHeight: 100,\n      ...opts\n    });\n  }\n\n  initializeState() {\n    const {gl, attributeManager} = this.state;\n\n    this.setState({\n      model: this.getModel(gl)\n    });\n\n    attributeManager.addInstanced(ATTRIBUTES, {\n      positions: {update: this.calculatePositions},\n      colors: {update: this.calculateColors}\n    });\n\n    this.updateCell();\n  }\n\n  willReceiveProps(oldProps, newProps) {\n    super.willReceiveProps(oldProps, newProps);\n\n    const cellSizeChanged =\n      newProps.unitWidth !== oldProps.unitWidth ||\n      newProps.unitHeight !== oldProps.unitHeight;\n\n    if (cellSizeChanged || this.state.viewportChanged) {\n      this.updateCell();\n    }\n  }\n\n  getModel(gl) {\n    return new Model({\n      program: new Program(gl, {\n        vs: glslify('./grid-layer-vertex.glsl'),\n        fs: glslify('./grid-layer-fragment.glsl'),\n        id: 'grid'\n      }),\n      geometry: new Geometry({\n        id: this.props.id,\n        drawMode: 'TRIANGLE_FAN',\n        vertices: new Float32Array([0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0])\n      }),\n      instanced: true\n    });\n  }\n\n  updateCell() {\n    const {width, height, unitWidth, unitHeight} = this.props;\n\n    const numCol = Math.ceil(width * 2 / unitWidth);\n    const numRow = Math.ceil(height * 2 / unitHeight);\n    this.setState({\n      numCol,\n      numRow,\n      numInstances: numCol * numRow\n    });\n\n    const {attributeManager} = this.state;\n    attributeManager.invalidateAll();\n\n    const MARGIN = 2;\n    const scale = new Float32Array([\n      unitWidth - MARGIN * 2,\n      unitHeight - MARGIN * 2,\n      1\n    ]);\n    this.setUniforms({scale});\n\n  }\n\n  calculatePositions(attribute, numInstances) {\n    const {unitWidth, unitHeight, width, height} = this.props;\n    const {numCol} = this.state;\n    const {value, size} = attribute;\n\n    for (let i = 0; i < numInstances; i++) {\n      const x = i % numCol;\n      const y = Math.floor(i / numCol);\n      value[i * size + 0] = x * unitWidth - width;\n      value[i * size + 1] = y * unitHeight - height;\n      value[i * size + 2] = 0;\n    }\n  }\n\n  calculateColors(attribute) {\n    const {data, unitWidth, unitHeight, width, height} = this.props;\n    const {numCol, numRow} = this.state;\n    const {value, size} = attribute;\n\n    value.fill(0.0);\n\n    for (const point of data) {\n      const pixel = this.project([point.position.y, point.position.x]);\n      const colId = Math.floor((pixel.x + width) / unitWidth);\n      const rowId = Math.floor((pixel.y + height) / unitHeight);\n      if (colId < numCol && rowId < numRow) {\n        const i4 = (colId + rowId * numCol) * size;\n        value[i4 + 2] = value[i4 + 0] += 1;\n        value[i4 + 1] += 5;\n        value[i4 + 3] = 0.6;\n      }\n    }\n\n    this.setUniforms({maxCount: Math.max(...value)});\n  }\n\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/layers/grid-layer/grid-layer.js"],"names":[],"mappings":"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","file":"grid-layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport Layer from '../../layer';\nimport {Model, Program, Geometry} from 'luma.gl';\nconst glslify = require('glslify');\n\nconst ATTRIBUTES = {\n  instancePositions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'},\n  instanceColors: {size: 4, '0': 'red', '1': 'green', '2': 'blue', '3': 'alpha'}\n};\n\nexport default class GridLayer extends Layer {\n\n  static get attributes() {\n    return ATTRIBUTES;\n  }\n\n  /**\n   * @classdesc\n   * GridLayer\n   *\n   * @class\n   * @param {object} opts\n   * @param {number} opts.unitWidth - width of the unit rectangle\n   * @param {number} opts.unitHeight - height of the unit rectangle\n   */\n  constructor(opts) {\n    super({\n      unitWidth: 100,\n      unitHeight: 100,\n      ...opts\n    });\n  }\n\n  initializeState() {\n    const {gl, attributeManager} = this.state;\n\n    this.setState({\n      model: this.getModel(gl)\n    });\n\n    attributeManager.addInstanced(ATTRIBUTES, {\n      instancePositions: {update: this.calculateInstancePositions},\n      instanceColors: {update: this.calculateInstanceColors}\n    });\n\n    this.updateCell();\n  }\n\n  willReceiveProps(oldProps, newProps) {\n    super.willReceiveProps(oldProps, newProps);\n\n    const cellSizeChanged =\n      newProps.unitWidth !== oldProps.unitWidth ||\n      newProps.unitHeight !== oldProps.unitHeight;\n\n    if (cellSizeChanged || this.state.viewportChanged) {\n      this.updateCell();\n    }\n  }\n\n  getModel(gl) {\n    return new Model({\n      program: new Program(gl, {\n        vs: glslify('./grid-layer-vertex.glsl'),\n        fs: glslify('./grid-layer-fragment.glsl'),\n        id: 'grid'\n      }),\n      geometry: new Geometry({\n        id: this.props.id,\n        drawMode: 'TRIANGLE_FAN',\n        vertices: new Float32Array([0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0])\n      }),\n      instanced: true\n    });\n  }\n\n  updateCell() {\n    const {width, height, unitWidth, unitHeight} = this.props;\n\n    const numCol = Math.ceil(width * 2 / unitWidth);\n    const numRow = Math.ceil(height * 2 / unitHeight);\n    this.setState({\n      numCol,\n      numRow,\n      numInstances: numCol * numRow\n    });\n\n    const {attributeManager} = this.state;\n    attributeManager.invalidateAll();\n\n    const MARGIN = 2;\n    const scale = new Float32Array([\n      unitWidth - MARGIN * 2,\n      unitHeight - MARGIN * 2,\n      1\n    ]);\n    this.setUniforms({scale});\n\n  }\n\n  calculateInstancePositions(attribute, numInstances) {\n    const {unitWidth, unitHeight, width, height} = this.props;\n    const {numCol} = this.state;\n    const {value, size} = attribute;\n\n    for (let i = 0; i < numInstances; i++) {\n      const x = i % numCol;\n      const y = Math.floor(i / numCol);\n      value[i * size + 0] = x * unitWidth - width;\n      value[i * size + 1] = y * unitHeight - height;\n      value[i * size + 2] = 0;\n    }\n  }\n\n  calculateInstanceColors(attribute) {\n    const {data, unitWidth, unitHeight, width, height} = this.props;\n    const {numCol, numRow} = this.state;\n    const {value, size} = attribute;\n\n    value.fill(0.0);\n\n    for (const point of data) {\n      const pixel = this.project([point.position.y, point.position.x]);\n      const colId = Math.floor((pixel.x + width) / unitWidth);\n      const rowId = Math.floor((pixel.y + height) / unitHeight);\n      if (colId < numCol && rowId < numRow) {\n        const i4 = (colId + rowId * numCol) * size;\n        value[i4 + 2] = value[i4 + 0] += 1;\n        value[i4 + 1] += 5;\n        value[i4 + 3] = 0.6;\n      }\n    }\n\n    this.setUniforms({maxCount: Math.max(...value)});\n  }\n\n}\n"]} |
@@ -22,4 +22,2 @@ 'use strict'; | ||
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } | ||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } | ||
@@ -52,4 +50,5 @@ | ||
var ATTRIBUTES = { | ||
positions: { size: 3, '0': 'x', '1': 'y', '2': 'unused' }, | ||
colors: { size: 3, '0': 'red', '1': 'green', '2': 'blue' } | ||
instancePositions: { size: 2, '0': 'x', '1': 'y' }, | ||
instanceElevations: { size: 1, '0': 'z' }, | ||
instanceColors: { size: 3, '0': 'red', '1': 'green', '2': 'blue' } | ||
}; | ||
@@ -79,3 +78,3 @@ | ||
dotRadius: 10, | ||
elevation: 0 | ||
elevation: 100 | ||
}, opts))); | ||
@@ -97,4 +96,5 @@ } | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
positions: { update: this.calculatePositions }, | ||
colors: { update: this.calculateColors } | ||
instancePositions: { update: this.calculateInstancePositions }, | ||
instanceElevations: { update: this.calculateInstanceElevations }, | ||
instanceColors: { update: this.calculateInstanceColors } | ||
}); | ||
@@ -116,7 +116,6 @@ | ||
if (dataChanged || viewportChanged) { | ||
attributeManager.invalidate('positions'); | ||
this.calculateRadiusAndAngle(); | ||
} | ||
if (dataChanged) { | ||
attributeManager.invalidate('colors'); | ||
attributeManager.invalidateAll(); | ||
} | ||
@@ -127,27 +126,47 @@ } | ||
value: function getModel(gl) { | ||
var NUM_SEGMENTS = 6; | ||
var PI2 = Math.PI * 2; | ||
var geometry = new _luma.CylinderGeometry({ | ||
id: this.props.id, | ||
radius: 1, | ||
topRadius: 1, | ||
bottomRadius: 1, | ||
topCap: true, | ||
bottomCap: true, | ||
height: 1, | ||
nradial: 6, | ||
nvertical: 1 | ||
}); | ||
var vertices = []; | ||
for (var i = 0; i < NUM_SEGMENTS; i++) { | ||
vertices = [].concat(_toConsumableArray(vertices), [Math.cos(PI2 * i / NUM_SEGMENTS), Math.sin(PI2 * i / NUM_SEGMENTS), 0]); | ||
} | ||
// const NUM_SEGMENTS = 6; | ||
// const PI2 = Math.PI * 2; | ||
// let vertices = []; | ||
// for (let i = 0; i < NUM_SEGMENTS; i++) { | ||
// vertices = [ | ||
// ...vertices, | ||
// Math.cos(PI2 * i / NUM_SEGMENTS), | ||
// Math.sin(PI2 * i / NUM_SEGMENTS), | ||
// 0 | ||
// ]; | ||
// } | ||
// const geometry = new Geometry({ | ||
// id: this.props.id, | ||
// drawMode: 'TRIANGLE_FAN', | ||
// vertices: new Float32Array(vertices) | ||
// }); | ||
return new _luma.Model({ | ||
program: new _luma.Program(gl, { | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* fragment shader for the hexagon-layer */\n#define SHADER_NAME hexagon-layer-vs\n\n// viewport: [x, y, width, height]\nconst float TILE_SIZE_1540259130 = 512.0;\nconst float PI = 3.1415926536;\n\n// non-linear projection: lnglats => zoom level depdendent projected coords\nvec2 mercatorProject(vec2 lnglat, float zoom) {\n // Note: Could be precomputed, at the expense of less simple API\n float scale = pow(2.0, zoom) * TILE_SIZE_1540259130 / (PI * 2.0);\n\n float longitude = lnglat.x;\n float latitude = lnglat.y;\n\n float lamda = radians(longitude);\n float phi = radians(latitude);\n\n float x = scale * (lamda + PI);\n float y = scale * (PI - log(tan(PI * 0.25 + phi * 0.5)));\n\n return vec2(x, y);\n}\n\nuniform float mercatorZoom;\n\nattribute vec3 vertices;\nattribute vec3 positions;\nattribute vec3 colors;\nattribute vec3 pickingColors;\n\nuniform mat4 projectionMatrix;\nuniform mat4 worldMatrix;\n\nuniform float radius;\nuniform float opacity;\nuniform float angle;\n\nuniform float renderPickingBuffer;\nuniform vec3 selected;\nvarying vec4 vColor;\n\nvoid main(void) {\n mat2 rotationMatrix = mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n vec3 rotatedVertices = vec3(rotationMatrix * vertices.xy * radius, vertices.z);\n vec4 verticesPositions = worldMatrix * vec4(rotatedVertices, 1.0);\n\n vec2 pos = mercatorProject(positions.xy, mercatorZoom);\n\n vec4 centroidPositions = worldMatrix * vec4(pos.xy, positions.z, 0.0);\n vec3 p = centroidPositions.xyz + verticesPositions.xyz;\n gl_Position = projectionMatrix * vec4(p, 1.0);\n\n float alpha = pickingColors == selected ? 0.5 : opacity;\n vColor = vec4(mix(colors / 255., pickingColors / 255., renderPickingBuffer), alpha);\n}\n', | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* fragment shader for the hexagon-layer */\n#define SHADER_NAME hexagon-layer-vs\n\n// viewport: [x, y, width, height]\nconst float TILE_SIZE_1540259130 = 512.0;\nconst float PI = 3.1415926536;\n\n// non-linear projection: lnglats => zoom level depdendent projected coords\nvec2 mercatorProject(vec2 lnglat, float zoom) {\n // Note: Could be precomputed, at the expense of less simple API\n float scale = pow(2.0, zoom) * TILE_SIZE_1540259130 / (PI * 2.0);\n\n float longitude = lnglat.x;\n float latitude = lnglat.y;\n\n float lamda = radians(longitude);\n float phi = radians(latitude);\n\n float x = scale * (lamda + PI);\n float y = scale * (PI - log(tan(PI * 0.25 + phi * 0.5)));\n\n return vec2(x, y);\n}\n\nuniform float mercatorZoom;\n\nattribute vec3 vertices;\n\nattribute vec2 instancePositions;\nattribute float instanceElevations;\nattribute vec3 instanceColors;\nattribute vec3 instancePickingColors;\n\nuniform mat4 worldMatrix;\nuniform mat4 projectionMatrix;\n\nuniform float radius;\nuniform float opacity;\nuniform float angle;\nuniform float elevation;\n\nuniform float renderPickingBuffer;\nuniform vec3 selected;\nvarying vec4 vColor;\n\nvoid main(void) {\n mat2 rotationMatrix = mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n vec3 rotatedVertices = vec3(rotationMatrix * vertices.xz * radius, vertices.y * elevation);\n vec4 verticesPositions = worldMatrix * vec4(rotatedVertices, 1.0);\n\n vec2 pos = mercatorProject(instancePositions.xy, mercatorZoom);\n\n vec4 centroidPositions = worldMatrix * vec4(pos.xy, instanceElevations, 0.0);\n vec3 p = centroidPositions.xyz + verticesPositions.xyz;\n gl_Position = projectionMatrix * vec4(p, 1.0);\n\n vec4 color = vec4(instanceColors / 255.0, opacity);\n vec4 pickingColor = vec4(instancePickingColors / 255.0, 1.);\n vColor = mix(color, pickingColor, renderPickingBuffer);\n\n // mat2 rotationMatrix = mat2(cos(angle), -sin(angle), sin(angle), cos(angle));\n // vec3 rotatedPosition = vec3(rotationMatrix * vertices.xy * radius, vertices.z * elevation);\n // vec4 verticesPositions = worldMatrix * vec4(rotatedPosition, 1.0);\n\n // vec2 pos = mercatorProject(instancePositions.xy + verticesPositions.xy, mercatorZoom);\n // vec3 p = vec3(pos.xy, instanceElevations + verticesPositions.z);\n // gl_Position = projectionMatrix * vec4(p, 1.0);\n\n // vec2 pos = mercatorProject(vertexPosition.xy, mercatorZoom);\n // vec4 centroidPositions = worldMatrix * vec4(pos.xy, positions.z, 0.0);\n // vec3 p = centroidPositions.xyz + verticesPositions.xyz;\n // vec3 elevatedPos = vec3(p.xy, max(0.01, positions.z * elevation));\n // gl_Position = projectionMatrix * vec4(elevatedPos, 1.0);\n}\n', | ||
fs: '// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* fragment shader for the hexagon-layer */\n#define SHADER_NAME hexagon-layer-fs\n\n#ifdef GL_ES\nprecision highp float;\n#define GLSLIFY 1\n#endif\n\nvarying vec4 vColor;\n\nvoid main(void) {\n gl_FragColor = vColor;\n}\n', | ||
id: 'hexagon' | ||
}), | ||
geometry: new _luma.Geometry({ | ||
id: this.props.id, | ||
drawMode: 'TRIANGLE_FAN', | ||
vertices: new Float32Array(vertices) | ||
}), | ||
geometry: geometry, | ||
instanced: true | ||
// indexed: true | ||
}); | ||
} | ||
}, { | ||
key: 'calculatePositions', | ||
value: function calculatePositions(attribute) { | ||
key: 'calculateInstancePositions', | ||
value: function calculateInstancePositions(attribute) { | ||
var data = this.props.data; | ||
@@ -168,3 +187,2 @@ var value = attribute.value; | ||
value[i + 1] = hexagon.centroid.y; | ||
value[i + 2] = 0; | ||
i += size; | ||
@@ -188,6 +206,7 @@ } | ||
}, { | ||
key: 'calculateColors', | ||
value: function calculateColors(attribute) { | ||
key: 'calculateInstanceElevations', | ||
value: function calculateInstanceElevations(attribute) { | ||
var data = this.props.data; | ||
var value = attribute.value; | ||
var size = attribute.size; | ||
@@ -203,6 +222,4 @@ var i = 0; | ||
value[i + 0] = hexagon.color[0]; | ||
value[i + 1] = hexagon.color[1]; | ||
value[i + 2] = hexagon.color[2]; | ||
i += 3; | ||
value[i + 0] = hexagon.elevation || 0; | ||
i += size; | ||
} | ||
@@ -224,3 +241,38 @@ } catch (err) { | ||
} | ||
}, { | ||
key: 'calculateInstanceColors', | ||
value: function calculateInstanceColors(attribute) { | ||
var data = this.props.data; | ||
var value = attribute.value; | ||
var i = 0; | ||
var _iteratorNormalCompletion3 = true; | ||
var _didIteratorError3 = false; | ||
var _iteratorError3 = undefined; | ||
try { | ||
for (var _iterator3 = data[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) { | ||
var hexagon = _step3.value; | ||
value[i + 0] = hexagon.color[0]; | ||
value[i + 1] = hexagon.color[1]; | ||
value[i + 2] = hexagon.color[2]; | ||
i += 3; | ||
} | ||
} catch (err) { | ||
_didIteratorError3 = true; | ||
_iteratorError3 = err; | ||
} finally { | ||
try { | ||
if (!_iteratorNormalCompletion3 && _iterator3.return) { | ||
_iterator3.return(); | ||
} | ||
} finally { | ||
if (_didIteratorError3) { | ||
throw _iteratorError3; | ||
} | ||
} | ||
} | ||
} | ||
// TODO this is the only place that uses hexagon vertices | ||
@@ -253,5 +305,6 @@ // consider move radius and angle calculation to the shader | ||
// Calculate angle that the perpendicular hexagon vertex axis is tilted | ||
angle: Math.acos(dx / dxy) * -Math.sign(dy), | ||
angle: Math.acos(dx / dxy) * -Math.sign(dy) + Math.PI / 2, | ||
// Allow user to fine tune radius | ||
radius: dxy / 2 * Math.min(1, this.props.dotRadius) | ||
radius: dxy / 2 * Math.min(1, this.props.dotRadius), | ||
elevation: this.props.elevation | ||
}); | ||
@@ -265,2 +318,2 @@ } | ||
exports.default = HexagonLayer; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/layers/hexagon-layer/hexagon-layer.js"],"names":[],"mappings":"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","file":"hexagon-layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport Layer from '../../layer';\nimport {Model, Program, Geometry} from 'luma.gl';\nconst glslify = require('glslify');\n\nconst ATTRIBUTES = {\n  positions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'},\n  colors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'}\n};\n\nexport default class HexagonLayer extends Layer {\n  /**\n   * @classdesc\n   * HexagonLayer\n   *\n   * @class\n   * @param {object} opts\n   *\n   * @param {number} opts.dotRadius - hexagon radius\n   * @param {number} opts.elevation - hexagon height\n   *\n   * @param {function} opts.onHexagonHovered(index, e) - popup selected index\n   * @param {function} opts.onHexagonClicked(index, e) - popup selected index\n   */\n  constructor(opts) {\n    super({\n      dotRadius: 10,\n      elevation: 0,\n      ...opts\n    });\n  }\n\n  initializeState() {\n    const {gl, attributeManager} = this.state;\n\n    this.setState({\n      model: this.getModel(gl)\n    });\n\n    attributeManager.addInstanced(ATTRIBUTES, {\n      positions: {update: this.calculatePositions},\n      colors: {update: this.calculateColors}\n    });\n\n    this.calculateRadiusAndAngle();\n  }\n\n  willReceiveProps(oldProps, newProps) {\n    super.willReceiveProps(oldProps, newProps);\n\n    const {dataChanged, viewportChanged, attributeManager} = this.state;\n\n    if (dataChanged || viewportChanged) {\n      attributeManager.invalidate('positions');\n      this.calculateRadiusAndAngle();\n    }\n    if (dataChanged) {\n      attributeManager.invalidate('colors');\n    }\n  }\n\n  getModel(gl) {\n    const NUM_SEGMENTS = 6;\n    const PI2 = Math.PI * 2;\n\n    let vertices = [];\n    for (let i = 0; i < NUM_SEGMENTS; i++) {\n      vertices = [\n        ...vertices,\n        Math.cos(PI2 * i / NUM_SEGMENTS),\n        Math.sin(PI2 * i / NUM_SEGMENTS),\n        0\n      ];\n    }\n\n    return new Model({\n      program: new Program(gl, {\n        vs: glslify('./hexagon-layer-vertex.glsl'),\n        fs: glslify('./hexagon-layer-fragment.glsl'),\n        id: 'hexagon'\n      }),\n      geometry: new Geometry({\n        id: this.props.id,\n        drawMode: 'TRIANGLE_FAN',\n        vertices: new Float32Array(vertices)\n      }),\n      instanced: true\n    });\n  }\n\n  calculatePositions(attribute) {\n    const {data} = this.props;\n    const {value, size} = attribute;\n    let i = 0;\n    for (const hexagon of data) {\n      value[i + 0] = hexagon.centroid.x;\n      value[i + 1] = hexagon.centroid.y;\n      value[i + 2] = 0;\n      i += size;\n    }\n  }\n\n  calculateColors(attribute) {\n    const {data} = this.props;\n    const {value} = attribute;\n    let i = 0;\n    for (const hexagon of data) {\n      value[i + 0] = hexagon.color[0];\n      value[i + 1] = hexagon.color[1];\n      value[i + 2] = hexagon.color[2];\n      i += 3;\n    }\n  }\n\n  // TODO this is the only place that uses hexagon vertices\n  // consider move radius and angle calculation to the shader\n  calculateRadiusAndAngle() {\n    const {data} = this.props;\n    if (!data || data.length === 0) {\n      return;\n    }\n\n    const vertices = data[0].vertices;\n    const vertex0 = vertices[0];\n    const vertex3 = vertices[3];\n\n    // transform to space coordinates\n    const spaceCoord0 = this.project({lat: vertex0[1], lon: vertex0[0]});\n    const spaceCoord3 = this.project({lat: vertex3[1], lon: vertex3[0]});\n\n    // distance between two close centroids\n    const dx = spaceCoord0.x - spaceCoord3.x;\n    const dy = spaceCoord0.y - spaceCoord3.y;\n    const dxy = Math.sqrt(dx * dx + dy * dy);\n\n    this.setUniforms({\n      // Calculate angle that the perpendicular hexagon vertex axis is tilted\n      angle: Math.acos(dx / dxy) * -Math.sign(dy),\n      // Allow user to fine tune radius\n      radius: dxy / 2 * Math.min(1, this.props.dotRadius)\n    });\n\n  }\n\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/layers/hexagon-layer/hexagon-layer.js"],"names":[],"mappings":"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","file":"hexagon-layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport Layer from '../../layer';\nimport {Model, Program, Geometry, CylinderGeometry} from 'luma.gl';\nconst glslify = require('glslify');\n\nconst ATTRIBUTES = {\n  instancePositions: {size: 2, '0': 'x', '1': 'y'},\n  instanceElevations: {size: 1, '0': 'z'},\n  instanceColors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'}\n};\n\nexport default class HexagonLayer extends Layer {\n  /**\n   * @classdesc\n   * HexagonLayer\n   *\n   * @class\n   * @param {object} opts\n   *\n   * @param {number} opts.dotRadius - hexagon radius\n   * @param {number} opts.elevation - hexagon height\n   *\n   * @param {function} opts.onHexagonHovered(index, e) - popup selected index\n   * @param {function} opts.onHexagonClicked(index, e) - popup selected index\n   */\n  constructor(opts) {\n    super({\n      dotRadius: 10,\n      elevation: 100,\n      ...opts\n    });\n  }\n\n  initializeState() {\n    const {gl, attributeManager} = this.state;\n\n    this.setState({\n      model: this.getModel(gl)\n    });\n\n    attributeManager.addInstanced(ATTRIBUTES, {\n      instancePositions: {update: this.calculateInstancePositions},\n      instanceElevations: {update: this.calculateInstanceElevations},\n      instanceColors: {update: this.calculateInstanceColors}\n    });\n\n    this.calculateRadiusAndAngle();\n  }\n\n  willReceiveProps(oldProps, newProps) {\n    super.willReceiveProps(oldProps, newProps);\n\n    const {dataChanged, viewportChanged, attributeManager} = this.state;\n\n    if (dataChanged || viewportChanged) {\n      this.calculateRadiusAndAngle();\n    }\n    if (dataChanged) {\n      attributeManager.invalidateAll();\n    }\n  }\n\n  getModel(gl) {\n    const geometry = new CylinderGeometry({\n      id: this.props.id,\n      radius: 1,\n      topRadius: 1,\n      bottomRadius: 1,\n      topCap: true,\n      bottomCap: true,\n      height: 1,\n      nradial: 6,\n      nvertical: 1\n    });\n\n    // const NUM_SEGMENTS = 6;\n    // const PI2 = Math.PI * 2;\n\n    // let vertices = [];\n    // for (let i = 0; i < NUM_SEGMENTS; i++) {\n    //   vertices = [\n    //     ...vertices,\n    //     Math.cos(PI2 * i / NUM_SEGMENTS),\n    //     Math.sin(PI2 * i / NUM_SEGMENTS),\n    //     0\n    //   ];\n    // }\n\n    // const geometry = new Geometry({\n    //   id: this.props.id,\n    //   drawMode: 'TRIANGLE_FAN',\n    //   vertices: new Float32Array(vertices)\n    // });\n\n    return new Model({\n      program: new Program(gl, {\n        vs: glslify('./hexagon-layer-vertex.glsl'),\n        fs: glslify('./hexagon-layer-fragment.glsl'),\n        id: 'hexagon'\n      }),\n      geometry,\n      instanced: true\n      // indexed: true\n    });\n  }\n\n  calculateInstancePositions(attribute) {\n    const {data} = this.props;\n    const {value, size} = attribute;\n    let i = 0;\n    for (const hexagon of data) {\n      value[i + 0] = hexagon.centroid.x;\n      value[i + 1] = hexagon.centroid.y;\n      i += size;\n    }\n  }\n\n  calculateInstanceElevations(attribute) {\n    const {data} = this.props;\n    const {value, size} = attribute;\n    let i = 0;\n    for (const hexagon of data) {\n      value[i + 0] = hexagon.elevation || 0;\n      i += size;\n    }\n  }\n\n  calculateInstanceColors(attribute) {\n    const {data} = this.props;\n    const {value} = attribute;\n    let i = 0;\n    for (const hexagon of data) {\n      value[i + 0] = hexagon.color[0];\n      value[i + 1] = hexagon.color[1];\n      value[i + 2] = hexagon.color[2];\n      i += 3;\n    }\n  }\n\n  // TODO this is the only place that uses hexagon vertices\n  // consider move radius and angle calculation to the shader\n  calculateRadiusAndAngle() {\n    const {data} = this.props;\n    if (!data || data.length === 0) {\n      return;\n    }\n\n    const vertices = data[0].vertices;\n    const vertex0 = vertices[0];\n    const vertex3 = vertices[3];\n\n    // transform to space coordinates\n    const spaceCoord0 = this.project({lat: vertex0[1], lon: vertex0[0]});\n    const spaceCoord3 = this.project({lat: vertex3[1], lon: vertex3[0]});\n\n    // distance between two close centroids\n    const dx = spaceCoord0.x - spaceCoord3.x;\n    const dy = spaceCoord0.y - spaceCoord3.y;\n    const dxy = Math.sqrt(dx * dx + dy * dy);\n\n    this.setUniforms({\n      // Calculate angle that the perpendicular hexagon vertex axis is tilted\n      angle: Math.acos(dx / dxy) * -Math.sign(dy) + Math.PI / 2,\n      // Allow user to fine tune radius\n      radius: dxy / 2 * Math.min(1, this.props.dotRadius),\n      elevation: this.props.elevation\n    });\n\n  }\n\n}\n"]} |
@@ -49,4 +49,4 @@ 'use strict'; | ||
var ATTRIBUTES = { | ||
positions: { size: 3, '0': 'x', '1': 'y', '2': 'unused' }, | ||
colors: { size: 3, '0': 'red', '1': 'green', '2': 'blue' } | ||
instancePositions: { size: 3, '0': 'x', '1': 'y', '2': 'unused' }, | ||
instanceColors: { size: 3, '0': 'red', '1': 'green', '2': 'blue' } | ||
}; | ||
@@ -92,4 +92,4 @@ | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
positions: { update: this.calculatePositions }, | ||
colors: { update: this.calculateColors } | ||
instancePositions: { update: this.calculateInstancePositions }, | ||
instanceColors: { update: this.calculateInstanceColors } | ||
}); | ||
@@ -121,4 +121,4 @@ } | ||
program: new _luma.Program(gl, { | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* vertex shader for the scatterplot-layer */\n#define SHADER_NAME scatterplot-layer-vs\n\n// viewport: [x, y, width, height]\nconst float TILE_SIZE_1540259130 = 512.0;\nconst float PI = 3.1415926536;\n\n// non-linear projection: lnglats => zoom level depdendent projected coords\nvec2 mercatorProject(vec2 lnglat, float zoom) {\n // Note: Could be precomputed, at the expense of less simple API\n float scale = pow(2.0, zoom) * TILE_SIZE_1540259130 / (PI * 2.0);\n\n float longitude = lnglat.x;\n float latitude = lnglat.y;\n\n float lamda = radians(longitude);\n float phi = radians(latitude);\n\n float x = scale * (lamda + PI);\n float y = scale * (PI - log(tan(PI * 0.25 + phi * 0.5)));\n\n return vec2(x, y);\n}\n\nuniform float mercatorZoom;\n\nattribute vec3 vertices;\nattribute vec3 positions;\nattribute vec3 colors;\n\nuniform float radius;\n\nuniform mat4 worldMatrix;\nuniform mat4 projectionMatrix;\n\nvarying vec3 vColor;\nattribute vec3 pickingColors;\nuniform float renderPickingBuffer;\n\nvoid main(void) {\n vColor = mix(colors / 255.0, pickingColors / 255.0, renderPickingBuffer);\n\n // vec2 pos = mercatorProjectViewport(positions.xy, mercatorZoom, mercatorCenter, viewport);\n vec2 pos = mercatorProject(positions.xy, mercatorZoom);\n vec3 p = vec3(pos, positions.z) + vertices * radius;\n gl_Position = projectionMatrix * worldMatrix * vec4(p, 1.0);\n}\n', | ||
fs: '// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* fragment shader for the scatterplot-layer */\n#define SHADER_NAME scatterplot-layer-fs\n\n#ifdef GL_ES\nprecision highp float;\n#define GLSLIFY 1\n#endif\n\nvarying vec3 vColor;\nuniform float opacity;\n\nvoid main(void) {\n gl_FragColor = vec4(vColor, opacity);\n}\n', | ||
vs: '#define GLSLIFY 1\n// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* vertex shader for the scatterplot-layer */\n#define SHADER_NAME scatterplot-layer-vs\n\n// viewport: [x, y, width, height]\nconst float TILE_SIZE_1540259130 = 512.0;\nconst float PI = 3.1415926536;\n\n// non-linear projection: lnglats => zoom level depdendent projected coords\nvec2 mercatorProject(vec2 lnglat, float zoom) {\n // Note: Could be precomputed, at the expense of less simple API\n float scale = pow(2.0, zoom) * TILE_SIZE_1540259130 / (PI * 2.0);\n\n float longitude = lnglat.x;\n float latitude = lnglat.y;\n\n float lamda = radians(longitude);\n float phi = radians(latitude);\n\n float x = scale * (lamda + PI);\n float y = scale * (PI - log(tan(PI * 0.25 + phi * 0.5)));\n\n return vec2(x, y);\n}\n\nuniform float mercatorZoom;\n\nattribute vec3 vertices;\nattribute vec3 instancePositions;\nattribute vec3 instanceColors;\nattribute vec3 instancePickingColors;\n\nuniform float radius;\nuniform float opacity;\n\nuniform mat4 worldMatrix;\nuniform mat4 projectionMatrix;\n\nvarying vec4 vColor;\nuniform float renderPickingBuffer;\n\nvoid main(void) {\n vec2 pos = mercatorProject(instancePositions.xy, mercatorZoom);\n vec3 p = vec3(pos, instancePositions.z) + vertices * radius;\n gl_Position = projectionMatrix * worldMatrix * vec4(p, 1.0);\n\n vec4 color = vec4(instanceColors / 255.0, 1.);\n vec4 pickingColor = vec4(instancePickingColors / 255.0, 1.);\n vColor = mix(color, pickingColor, renderPickingBuffer);\n}\n', | ||
fs: '// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the "Software"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* fragment shader for the scatterplot-layer */\n#define SHADER_NAME scatterplot-layer-fs\n\n#ifdef GL_ES\nprecision highp float;\n#define GLSLIFY 1\n#endif\n\nvarying vec4 vColor;\n\nvoid main(void) {\n gl_FragColor = vColor;\n}\n', | ||
id: 'scatterplot' | ||
@@ -144,4 +144,4 @@ }), | ||
}, { | ||
key: 'calculatePositions', | ||
value: function calculatePositions(attribute) { | ||
key: 'calculateInstancePositions', | ||
value: function calculateInstancePositions(attribute) { | ||
var data = this.props.data; | ||
@@ -181,4 +181,4 @@ var value = attribute.value; | ||
}, { | ||
key: 'calculateColors', | ||
value: function calculateColors(attribute) { | ||
key: 'calculateInstanceColors', | ||
value: function calculateInstanceColors(attribute) { | ||
var data = this.props.data; | ||
@@ -240,2 +240,2 @@ var value = attribute.value; | ||
exports.default = ScatterplotLayer; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/layers/scatterplot-layer/scatterplot-layer.js"],"names":[],"mappings":"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","file":"scatterplot-layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport Layer from '../../layer';\nimport {Model, Program, Geometry} from 'luma.gl';\nconst glslify = require('glslify');\n\nconst ATTRIBUTES = {\n  positions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'},\n  colors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'}\n};\n\nexport default class ScatterplotLayer extends Layer {\n\n  static get attributes() {\n    return ATTRIBUTES;\n  }\n\n  /*\n   * @classdesc\n   * ScatterplotLayer\n   *\n   * @class\n   * @param {object} props\n   * @param {number} props.radius - point radius\n   */\n  constructor(props) {\n    super(props);\n  }\n\n  initializeState() {\n    const {gl} = this.state;\n    const {attributeManager} = this.state;\n\n    this.setState({\n      model: this.getModel(gl)\n    });\n\n    attributeManager.addInstanced(ATTRIBUTES, {\n      positions: {update: this.calculatePositions},\n      colors: {update: this.calculateColors}\n    });\n  }\n\n  didMount() {\n    this.updateUniforms();\n  }\n\n  willReceiveProps(oldProps, newProps) {\n    super.willReceiveProps(oldProps, newProps);\n    this.updateUniforms();\n  }\n\n  getModel(gl) {\n    const NUM_SEGMENTS = 16;\n    const PI2 = Math.PI * 2;\n\n    let vertices = [];\n    for (let i = 0; i < NUM_SEGMENTS; i++) {\n      vertices = [\n        ...vertices,\n        Math.cos(PI2 * i / NUM_SEGMENTS),\n        Math.sin(PI2 * i / NUM_SEGMENTS),\n        0\n      ];\n    }\n\n    return new Model({\n      program: new Program(gl, {\n        vs: glslify('./scatterplot-layer-vertex.glsl'),\n        fs: glslify('./scatterplot-layer-fragment.glsl'),\n        id: 'scatterplot'\n      }),\n      geometry: new Geometry({\n        drawMode: 'TRIANGLE_FAN',\n        vertices: new Float32Array(vertices)\n      }),\n      instanced: true\n    });\n  }\n\n  updateUniforms() {\n    this.calculateRadius();\n    const {radius} = this.state;\n    this.setUniforms({\n      radius\n    });\n  }\n\n  calculatePositions(attribute) {\n    const {data} = this.props;\n    const {value, size} = attribute;\n    let i = 0;\n    for (const point of data) {\n      value[i + 0] = point.position.x;\n      value[i + 1] = point.position.y;\n      value[i + 2] = point.position.z;\n      i += size;\n    }\n  }\n\n  calculateColors(attribute) {\n    const {data} = this.props;\n    const {value, size} = attribute;\n    let i = 0;\n    for (const point of data) {\n      value[i + 0] = point.color[0];\n      value[i + 1] = point.color[1];\n      value[i + 2] = point.color[2];\n      i += size;\n    }\n  }\n\n  calculateRadius() {\n    // use radius if specified\n    if (this.props.radius) {\n      this.state.radius = this.props.radius;\n      return;\n    }\n\n    const pixel0 = this.project({lon: -122, lat: 37.5});\n    const pixel1 = this.project({lon: -122, lat: 37.5002});\n\n    const dx = pixel0.x - pixel1.x;\n    const dy = pixel0.y - pixel1.y;\n\n    this.state.radius = Math.max(Math.sqrt(dx * dx + dy * dy), 2.0);\n  }\n\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/layers/scatterplot-layer/scatterplot-layer.js"],"names":[],"mappings":"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","file":"scatterplot-layer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport Layer from '../../layer';\nimport {Model, Program, Geometry} from 'luma.gl';\nconst glslify = require('glslify');\n\nconst ATTRIBUTES = {\n  instancePositions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'},\n  instanceColors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'}\n};\n\nexport default class ScatterplotLayer extends Layer {\n\n  static get attributes() {\n    return ATTRIBUTES;\n  }\n\n  /*\n   * @classdesc\n   * ScatterplotLayer\n   *\n   * @class\n   * @param {object} props\n   * @param {number} props.radius - point radius\n   */\n  constructor(props) {\n    super(props);\n  }\n\n  initializeState() {\n    const {gl} = this.state;\n    const {attributeManager} = this.state;\n\n    this.setState({\n      model: this.getModel(gl)\n    });\n\n    attributeManager.addInstanced(ATTRIBUTES, {\n      instancePositions: {update: this.calculateInstancePositions},\n      instanceColors: {update: this.calculateInstanceColors}\n    });\n  }\n\n  didMount() {\n    this.updateUniforms();\n  }\n\n  willReceiveProps(oldProps, newProps) {\n    super.willReceiveProps(oldProps, newProps);\n    this.updateUniforms();\n  }\n\n  getModel(gl) {\n    const NUM_SEGMENTS = 16;\n    const PI2 = Math.PI * 2;\n\n    let vertices = [];\n    for (let i = 0; i < NUM_SEGMENTS; i++) {\n      vertices = [\n        ...vertices,\n        Math.cos(PI2 * i / NUM_SEGMENTS),\n        Math.sin(PI2 * i / NUM_SEGMENTS),\n        0\n      ];\n    }\n\n    return new Model({\n      program: new Program(gl, {\n        vs: glslify('./scatterplot-layer-vertex.glsl'),\n        fs: glslify('./scatterplot-layer-fragment.glsl'),\n        id: 'scatterplot'\n      }),\n      geometry: new Geometry({\n        drawMode: 'TRIANGLE_FAN',\n        vertices: new Float32Array(vertices)\n      }),\n      instanced: true\n    });\n  }\n\n  updateUniforms() {\n    this.calculateRadius();\n    const {radius} = this.state;\n    this.setUniforms({\n      radius\n    });\n  }\n\n  calculateInstancePositions(attribute) {\n    const {data} = this.props;\n    const {value, size} = attribute;\n    let i = 0;\n    for (const point of data) {\n      value[i + 0] = point.position.x;\n      value[i + 1] = point.position.y;\n      value[i + 2] = point.position.z;\n      i += size;\n    }\n  }\n\n  calculateInstanceColors(attribute) {\n    const {data} = this.props;\n    const {value, size} = attribute;\n    let i = 0;\n    for (const point of data) {\n      value[i + 0] = point.color[0];\n      value[i + 1] = point.color[1];\n      value[i + 2] = point.color[2];\n      i += size;\n    }\n  }\n\n  calculateRadius() {\n    // use radius if specified\n    if (this.props.radius) {\n      this.state.radius = this.props.radius;\n      return;\n    }\n\n    const pixel0 = this.project({lon: -122, lat: 37.5});\n    const pixel1 = this.project({lon: -122, lat: 37.5002});\n\n    const dx = pixel0.x - pixel1.x;\n    const dy = pixel0.y - pixel1.y;\n\n    this.state.radius = Math.max(Math.sqrt(dx * dx + dy * dy), 2.0);\n  }\n\n}\n"]} |
@@ -195,3 +195,3 @@ 'use strict'; | ||
try { | ||
gl = (0, _luma.createGLContext)(canvas); | ||
gl = (0, _luma.createGLContext)(canvas, { preserveDrawingBuffer: true }); | ||
} catch (error) { | ||
@@ -227,3 +227,3 @@ this.props.onInitializationFailed(error); | ||
var pickedModels = scene.pickModels(gl, { camera: camera, x: x, y: y }); | ||
var pickedModels = scene.pickModels(gl, { camera: camera, x: x * 2, y: y * 2 }); | ||
@@ -329,2 +329,2 @@ return pickedModels; | ||
exports.default = WebGLRenderer; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/webgl-renderer.js"],"names":[],"mappings":"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","file":"webgl-renderer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* eslint-disable no-console, no-try-catch */\n/* global console */\nimport React, {PropTypes} from 'react';\nimport autobind from 'autobind-decorator';\nimport {createGLContext, Camera, Scene, Events, Fx, glGet} from 'luma.gl';\nimport throttle from 'lodash.throttle';\n\nconst PROP_TYPES = {\n  id: PropTypes.string,\n\n  width: PropTypes.number.isRequired,\n  height: PropTypes.number.isRequired,\n\n  pixelRatio: PropTypes.number,\n  viewport: PropTypes.object.isRequired,\n  camera: PropTypes.instanceOf(Camera).isRequired,\n  scene: PropTypes.instanceOf(Scene),\n  blending: PropTypes.object,\n  events: PropTypes.object,\n\n  onRendererInitialized: PropTypes.func.isRequired,\n  onInitializationFailed: PropTypes.func,\n  onError: PropTypes.func,\n\n  onBeforeRenderFrame: PropTypes.func,\n  onAfterRenderFrame: PropTypes.func,\n  onBeforeRenderPickingScene: PropTypes.func,\n  onAfterRenderPickingScene: PropTypes.func,\n\n  onNeedRedraw: PropTypes.func,\n  onMouseMove: PropTypes.func,\n  onClick: PropTypes.func\n};\n\nconst DEFAULT_PROPS = {\n  id: 'webgl-canvas',\n  scene: null,\n  onRendererInitialized: () => {},\n  onInitializationFailed: error => console.error(error),\n  onError: error => {\n    throw error;\n  },\n  onBeforeRenderFrame: () => {},\n  onAfterRenderFrame: () => {},\n  onBeforeRenderPickingScene: () => {},\n  onAfterRenderPickingScene: () => {},\n\n  onNeedRedraw: () => true,\n  onMouseMove: () => {},\n  onClick: () => {}\n};\n\nexport default class WebGLRenderer extends React.Component {\n\n  static get propTypes() {\n    return PROP_TYPES;\n  }\n\n  static get defaultProps() {\n    return DEFAULT_PROPS;\n  }\n\n  /**\n   * @classdesc\n   * Small react component that uses Luma.GL to initialize a WebGL context.\n   *\n   * Returns a canvas, creates a basic WebGL context, a camera and a scene,\n   * sets up a renderloop, and registers some basic event handlers\n   *\n   * @class\n   * @param {Object} props - see propTypes documentation\n   */\n  constructor(props) {\n    super(props);\n    this.state = {\n      gl: null\n    };\n  }\n\n  componentDidMount() {\n    const canvas = this.refs.overlay;\n    this._initWebGL(canvas);\n    this._animationLoop();\n  }\n\n  /**\n   * Initialize LumaGL library and through it WebGL\n   * @param {string} canvas\n   */\n  _initWebGL(canvas) {\n\n    let gl;\n    try {\n      gl = createGLContext(canvas);\n    } catch (error) {\n      this.props.onInitializationFailed(error);\n      return;\n    }\n\n    const events = Events.create(canvas, {\n      cacheSize: false,\n      cachePosition: false,\n      centerOrigin: false,\n      onClick: this._onClick,\n      onMouseMove: throttle(this._onMouseMove, 100)\n    });\n\n    this.setState({gl, events});\n\n    this.props.onRendererInitialized({gl});\n  }\n\n  // TODO - move this back to luma.gl/scene.js\n  /* eslint-disable max-statements */\n  _pick(x, y) {\n    const {gl} = this.state;\n    const {camera, scene} = this.props;\n\n    const pickedModels = scene.pickModels(gl, {camera, x, y});\n\n    return pickedModels;\n  }\n\n  @autobind\n  _onClick(event) {\n    const picked = this._pick(event.x, event.y);\n    this.props.onClick({...event, picked});\n  }\n\n  @autobind\n  _onMouseMove(event) {\n    const picked = this._pick(event.x, event.y);\n    this.props.onMouseMove({...event, picked});\n  }\n\n  _renderFrame() {\n    const {\n      viewport: {x, y, width, height},\n      blending: {enable, blendFunc, blendEquation},\n      onBeforeRenderFrame,\n      onAfterRenderFrame,\n      onNeedRedraw,\n      pixelRatio,\n      camera,\n      scene\n    } = this.props;\n\n    const {gl} = this.state;\n    if (!gl || !scene) {\n      return;\n    }\n\n    // Note: Do this after gl check, in case onNeedRedraw clears flags\n    if (!onNeedRedraw()) {\n      return;\n    }\n\n    // clear depth and color buffers\n    gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n\n    // update viewport to latest props\n    // (typically changed by app on browser resize etc)\n    gl.viewport(\n      x * pixelRatio,\n      y * pixelRatio,\n      width * pixelRatio,\n      height * pixelRatio\n    );\n\n    // setup bledning\n    if (enable) {\n      gl.enable(gl.BLEND);\n      gl.blendFunc(...blendFunc.map(s => glGet(gl, s)));\n      gl.blendEquation(glGet(gl, blendEquation));\n    } else {\n      gl.disable(gl.BLEND);\n    }\n\n    onBeforeRenderFrame();\n    scene.render({camera});\n    onAfterRenderFrame();\n  }\n\n  /**\n   * Main WebGL animation loop\n   */\n  @autobind\n  _animationLoop() {\n    this._renderFrame();\n    // Keep registering ourselves for the next animation frame\n    Fx.requestAnimationFrame(this._animationLoop);\n  }\n\n  render() {\n    const {id, width, height, pixelRatio} = this.props;\n    return (\n      <canvas\n        ref={ 'overlay' }\n        id={ id }\n        width={ width * pixelRatio || 1 }\n        height={ height * pixelRatio || 1 }\n        style={ {width, height} }/>\n    );\n  }\n\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/webgl-renderer.js"],"names":[],"mappings":"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","file":"webgl-renderer.js","sourcesContent":["// Copyright (c) 2015 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/* eslint-disable no-console, no-try-catch */\n/* global console */\nimport React, {PropTypes} from 'react';\nimport autobind from 'autobind-decorator';\nimport {createGLContext, Camera, Scene, Events, Fx, glGet} from 'luma.gl';\nimport throttle from 'lodash.throttle';\n\nconst PROP_TYPES = {\n  id: PropTypes.string,\n\n  width: PropTypes.number.isRequired,\n  height: PropTypes.number.isRequired,\n\n  pixelRatio: PropTypes.number,\n  viewport: PropTypes.object.isRequired,\n  camera: PropTypes.instanceOf(Camera).isRequired,\n  scene: PropTypes.instanceOf(Scene),\n  blending: PropTypes.object,\n  events: PropTypes.object,\n\n  onRendererInitialized: PropTypes.func.isRequired,\n  onInitializationFailed: PropTypes.func,\n  onError: PropTypes.func,\n\n  onBeforeRenderFrame: PropTypes.func,\n  onAfterRenderFrame: PropTypes.func,\n  onBeforeRenderPickingScene: PropTypes.func,\n  onAfterRenderPickingScene: PropTypes.func,\n\n  onNeedRedraw: PropTypes.func,\n  onMouseMove: PropTypes.func,\n  onClick: PropTypes.func\n};\n\nconst DEFAULT_PROPS = {\n  id: 'webgl-canvas',\n  scene: null,\n  onRendererInitialized: () => {},\n  onInitializationFailed: error => console.error(error),\n  onError: error => {\n    throw error;\n  },\n  onBeforeRenderFrame: () => {},\n  onAfterRenderFrame: () => {},\n  onBeforeRenderPickingScene: () => {},\n  onAfterRenderPickingScene: () => {},\n\n  onNeedRedraw: () => true,\n  onMouseMove: () => {},\n  onClick: () => {}\n};\n\nexport default class WebGLRenderer extends React.Component {\n\n  static get propTypes() {\n    return PROP_TYPES;\n  }\n\n  static get defaultProps() {\n    return DEFAULT_PROPS;\n  }\n\n  /**\n   * @classdesc\n   * Small react component that uses Luma.GL to initialize a WebGL context.\n   *\n   * Returns a canvas, creates a basic WebGL context, a camera and a scene,\n   * sets up a renderloop, and registers some basic event handlers\n   *\n   * @class\n   * @param {Object} props - see propTypes documentation\n   */\n  constructor(props) {\n    super(props);\n    this.state = {\n      gl: null\n    };\n  }\n\n  componentDidMount() {\n    const canvas = this.refs.overlay;\n    this._initWebGL(canvas);\n    this._animationLoop();\n  }\n\n  /**\n   * Initialize LumaGL library and through it WebGL\n   * @param {string} canvas\n   */\n  _initWebGL(canvas) {\n\n    let gl;\n    try {\n      gl = createGLContext(canvas, {preserveDrawingBuffer: true});\n    } catch (error) {\n      this.props.onInitializationFailed(error);\n      return;\n    }\n\n    const events = Events.create(canvas, {\n      cacheSize: false,\n      cachePosition: false,\n      centerOrigin: false,\n      onClick: this._onClick,\n      onMouseMove: throttle(this._onMouseMove, 100)\n    });\n\n    this.setState({gl, events});\n\n    this.props.onRendererInitialized({gl});\n  }\n\n  // TODO - move this back to luma.gl/scene.js\n  /* eslint-disable max-statements */\n  _pick(x, y) {\n    const {gl} = this.state;\n    const {camera, scene} = this.props;\n\n    const pickedModels = scene.pickModels(gl, {camera, x: x * 2, y: y * 2});\n\n    return pickedModels;\n  }\n\n  @autobind\n  _onClick(event) {\n    const picked = this._pick(event.x, event.y);\n    this.props.onClick({...event, picked});\n  }\n\n  @autobind\n  _onMouseMove(event) {\n    const picked = this._pick(event.x, event.y);\n    this.props.onMouseMove({...event, picked});\n  }\n\n  _renderFrame() {\n    const {\n      viewport: {x, y, width, height},\n      blending: {enable, blendFunc, blendEquation},\n      onBeforeRenderFrame,\n      onAfterRenderFrame,\n      onNeedRedraw,\n      pixelRatio,\n      camera,\n      scene\n    } = this.props;\n\n    const {gl} = this.state;\n    if (!gl || !scene) {\n      return;\n    }\n\n    // Note: Do this after gl check, in case onNeedRedraw clears flags\n    if (!onNeedRedraw()) {\n      return;\n    }\n\n    // clear depth and color buffers\n    gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n\n    // update viewport to latest props\n    // (typically changed by app on browser resize etc)\n    gl.viewport(\n      x * pixelRatio,\n      y * pixelRatio,\n      width * pixelRatio,\n      height * pixelRatio\n    );\n\n    // setup bledning\n    if (enable) {\n      gl.enable(gl.BLEND);\n      gl.blendFunc(...blendFunc.map(s => glGet(gl, s)));\n      gl.blendEquation(glGet(gl, blendEquation));\n    } else {\n      gl.disable(gl.BLEND);\n    }\n\n    onBeforeRenderFrame();\n    scene.render({camera});\n    onAfterRenderFrame();\n  }\n\n  /**\n   * Main WebGL animation loop\n   */\n  @autobind\n  _animationLoop() {\n    this._renderFrame();\n    // Keep registering ourselves for the next animation frame\n    Fx.requestAnimationFrame(this._animationLoop);\n  }\n\n  render() {\n    const {id, width, height, pixelRatio} = this.props;\n    return (\n      <canvas\n        ref={ 'overlay' }\n        id={ id }\n        width={ width * pixelRatio || 1 }\n        height={ height * pixelRatio || 1 }\n        style={ {width, height} }/>\n    );\n  }\n\n}\n"]} |
@@ -5,3 +5,3 @@ { | ||
"license": "MIT", | ||
"version": "3.0.0-beta7", | ||
"version": "3.0.0-beta8", | ||
"keywords": [ | ||
@@ -99,6 +99,6 @@ "webgl", | ||
"test-node": "babel-node --only=luma.gl,deck.gl/src,deck.gl/test test/node.js | faucet", | ||
"test-browser": "budo test/browser.js:build/test-bundle.js --dir test -t babelify --live --open --port 3001 --watch-glob '**/*.{html,css,scss,js}' -- -t babelify -t glslify", | ||
"test-browser": "budo test/browser.js:build/test-bundle.js --dir test --live --open --port 3001 --watch-glob '**/*.{html,css,scss,js,glsl}' -- -t babelify", | ||
"test-electron": "browserify test/electron.js | testron | faucet", | ||
"start": "budo example/main.js:example/bundle.js --live --open --port 3000 --watch-glob '**/*.{html,css,js}' -- -t babelify -t glslify -t envify" | ||
"start": "budo example/main.js:example/bundle.js --live --open --port 3000 --css example/main.css --title 'deck.gl' --watch-glob '**/*.{html,css,js,glsl}' -- -t babelify -t envify" | ||
} | ||
} |
@@ -247,3 +247,3 @@ # deck.gl | ||
**Note:** The application can provide some buffers and let others be managed | ||
by the layer. As an example management of the `pickingColors` buffer is | ||
by the layer. As an example management of the `instancePickingColors` buffer is | ||
normally left to the layer. | ||
@@ -250,0 +250,0 @@ |
@@ -31,4 +31,3 @@ /* eslint-disable guard-for-in */ | ||
// Returns attributes in a format suitable for use with Luma.gl objects | ||
// | ||
// Returns attributes in a format suitable for use with Luma.gl Model/Program | ||
getAttributes() { | ||
@@ -38,2 +37,3 @@ return this.attributes; | ||
// Returns the redraw flag | ||
getNeedsRedraw({clearFlag}) { | ||
@@ -47,8 +47,9 @@ const needsRedraw = this.needsRedraw; | ||
// Adds a static attribute (that is not auto updated) | ||
add(attributes, updaters) { | ||
const newAttributes = this._add(attributes, updaters, {}); | ||
// and instancedAttributes (for updating when data changes) | ||
Object.assign(this.attributes, newAttributes); | ||
} | ||
// Adds a dynamic attribute, that is autoupdated | ||
addDynamic(attributes, updaters) { | ||
@@ -58,6 +59,6 @@ const newAttributes = this._add(attributes, updaters, { | ||
}); | ||
// and instancedAttributes (for updating when data changes) | ||
Object.assign(this.attributes, newAttributes); | ||
} | ||
// Adds an instanced attribute that is autoupdated | ||
addInstanced(attributes, updaters) { | ||
@@ -69,33 +70,6 @@ const newAttributes = this._add(attributes, updaters, { | ||
Object.assign(this.attributes, newAttributes); | ||
// and instancedAttributes (for updating when data changes) | ||
Object.assign(this.instancedAttributes, newAttributes); | ||
} | ||
addVertices(vertexArray) { | ||
assert(vertexArray instanceof Float32Array); | ||
this.add({ | ||
vertices: {value: vertexArray, size: 3, '0': 'x', '1': 'y', '2': 'z'} | ||
}); | ||
} | ||
addNormals(normalArray) { | ||
assert(normalArray instanceof Float32Array); | ||
this.add({ | ||
normals: {value: normalArray, size: 3, '0': 'x', '1': 'y', '2': 'z'} | ||
}); | ||
} | ||
addIndices(indexArray, gl) { | ||
assert(indexArray instanceof Uint16Array); | ||
assert(gl); | ||
this.add({ | ||
indices: { | ||
value: indexArray, | ||
size: 1, | ||
bufferType: gl.ELEMENT_ARRAY_BUFFER, | ||
drawMode: gl.STATIC_DRAW, | ||
'0': 'index' | ||
} | ||
}); | ||
} | ||
// Marks an attribute for update | ||
@@ -102,0 +76,0 @@ invalidate(attributeName) { |
@@ -34,2 +34,4 @@ // Copyright (c) 2015 Uber Technologies, Inc. | ||
const DEFAULT_PIXEL_RATIO = typeof window !== 'undefined' ? window.devicePixelRatio : 1; | ||
const PROP_TYPES = { | ||
@@ -42,3 +44,5 @@ width: PropTypes.number.isRequired, | ||
// TODO - replace with actual map view state props, build matrix from those | ||
projectionMatrix: PropTypes.any | ||
projectionMatrix: PropTypes.any, | ||
pixelRatio: PropTypes.number, | ||
onWebGLInitialized: PropTypes.func | ||
}; | ||
@@ -49,3 +53,5 @@ | ||
camera: null, | ||
projectionMatrix: null | ||
projectionMatrix: null, | ||
pixelRatio: DEFAULT_PIXEL_RATIO, | ||
onWebGLInitialized: () => {} | ||
}; | ||
@@ -103,2 +109,3 @@ | ||
_onRendererInitialized({gl}) { | ||
this.props.onWebGLInitialized(gl); | ||
this.setState({ | ||
@@ -144,3 +151,3 @@ gl, | ||
const { | ||
width, height, layers, blending, projectionMatrix, ...otherProps | ||
width, height, layers, blending, projectionMatrix, pixelRatio, ...otherProps | ||
} = this.props; | ||
@@ -188,3 +195,3 @@ let {camera} = this.props; | ||
blending={ blending } | ||
pixelRatio={ window.devicePixelRatio } | ||
pixelRatio={ pixelRatio } | ||
@@ -191,0 +198,0 @@ onRendererInitialized={ this._onRendererInitialized } |
@@ -61,3 +61,4 @@ // Copyright (c) 2015 Uber Technologies, Inc. | ||
const ATTRIBUTES = { | ||
pickingColors: {size: 3, '0': 'pickRed', '1': 'pickGreen', '2': 'pickBlue'} | ||
instancePickingColors: | ||
{size: 3, '0': 'pickRed', '1': 'pickGreen', '2': 'pickBlue'} | ||
}; | ||
@@ -323,6 +324,6 @@ | ||
const {attributeManager} = this.state; | ||
// All instanced layers get pickingColors attribute by default | ||
// All instanced layers get instancePickingColors attribute by default | ||
// Their shaders can use it to render a picking scene | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
pickingColors: {update: this.calculatePickingColors} | ||
instancePickingColors: {update: this.calculateInstancePickingColors} | ||
}); | ||
@@ -380,3 +381,3 @@ | ||
calculatePickingColors(attribute, numInstances) { | ||
calculateInstancePickingColors(attribute, numInstances) { | ||
const {value, size} = attribute; | ||
@@ -414,4 +415,5 @@ // add 1 to index to seperate from no selection | ||
info.index = this.decodePickingColor(color); | ||
if (Array.isArray(this.data)) { | ||
info.object = this.data[info.index]; | ||
// If props.data is an indexable array, get the object | ||
if (Array.isArray(this.props.data)) { | ||
info.object = this.props.data[info.index]; | ||
} | ||
@@ -424,2 +426,3 @@ info.geoCoords = this.unproject({x: info.x, y: info.y}); | ||
const {color} = info; | ||
const selectedPickingColor = new Float32Array(3); | ||
@@ -462,8 +465,3 @@ selectedPickingColor[0] = color[0]; | ||
this.setState({ | ||
viewport: { | ||
x: 0, | ||
y: 0, | ||
width, | ||
height | ||
}, | ||
viewport: {x: 0, y: 0, width, height}, | ||
mercator: ViewportMercator({ | ||
@@ -470,0 +468,0 @@ width, height, latitude, longitude, zoom, |
@@ -26,3 +26,3 @@ // Copyright (c) 2015 Uber Technologies, Inc. | ||
const ATTRIBUTES = { | ||
positions: {size: 4, '0': 'x0', '1': 'y0', '2': 'x1', '3': 'y1'} | ||
instancePositions: {size: 4, '0': 'x0', '1': 'y0', '2': 'x1', '3': 'y1'} | ||
}; | ||
@@ -38,5 +38,12 @@ | ||
*/ | ||
constructor(opts) { | ||
constructor({ | ||
strokeWidth = 1, | ||
color0 = [255, 0, 0], | ||
color1 = [0, 0, 255], | ||
...opts | ||
} = {}) { | ||
super({ | ||
strokeWidth: 1, | ||
strokeWidth, | ||
color0, | ||
color1, | ||
...opts | ||
@@ -54,3 +61,3 @@ }); | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
positions: {update: this.calculatePositions} | ||
instancePositions: {update: this.calculateInstancePositions} | ||
}); | ||
@@ -62,6 +69,4 @@ | ||
willReceiveProps(oldProps, nextProps) { | ||
super.willReceiveProps(oldProps, nextProps); | ||
this.state.model.userData.strokeWidth = nextProps.strokeWidth; | ||
this.updateColors(); | ||
@@ -71,6 +76,6 @@ } | ||
createModel(gl) { | ||
let vertices = []; | ||
let positions = []; | ||
const NUM_SEGMENTS = 50; | ||
for (let i = 0; i < NUM_SEGMENTS; i++) { | ||
vertices = [...vertices, i, i, i]; | ||
positions = [...positions, i, i, i]; | ||
} | ||
@@ -87,13 +92,11 @@ | ||
drawMode: 'LINE_STRIP', | ||
vertices: new Float32Array(vertices) | ||
vertices: new Float32Array(positions) | ||
}), | ||
instanced: true, | ||
onBeforeRender() { | ||
const {gl} = this.program; | ||
this.userData.oldStrokeWidth = gl.getParameter(gl.LINE_WIDTH); | ||
gl.lineWidth(this.userData.strokeWidth || 1); | ||
this.program.gl.lineWidth(this.userData.strokeWidth || 1); | ||
}, | ||
onAfterRender() { | ||
const {gl} = this.program; | ||
gl.lineWidth(this.userData.oldStrokeWidth || 1); | ||
this.program.gl.lineWidth(this.userData.oldStrokeWidth || 1); | ||
} | ||
@@ -104,13 +107,9 @@ }); | ||
updateColors() { | ||
// Get colors from first object | ||
const object = this.getFirstObject(); | ||
if (object) { | ||
this.setUniforms({ | ||
color0: object.colors.c0, | ||
color1: object.colors.c1 | ||
}); | ||
} | ||
this.setUniforms({ | ||
color0: this.props.color0, | ||
color1: this.props.color1 | ||
}); | ||
} | ||
calculatePositions(attribute) { | ||
calculateInstancePositions(attribute) { | ||
const {data} = this.props; | ||
@@ -117,0 +116,0 @@ const {value, size} = attribute; |
@@ -29,4 +29,4 @@ // Copyright (c) 2015 Uber Technologies, Inc. | ||
const ATTRIBUTES = { | ||
vertices: {size: 3, '0': 'x', '1': 'y', '2': 'unused'}, | ||
indices: {size: 1, '0': 'index'}, | ||
positions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'}, | ||
colors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'}, | ||
@@ -63,3 +63,3 @@ // Override picking colors to prevent auto allocation | ||
indices: {update: this.calculateIndices}, | ||
vertices: {update: this.calculateVertices}, | ||
positions: {update: this.calculatePositions}, | ||
colors: {update: this.calculateColors}, | ||
@@ -110,3 +110,3 @@ // Instanced attributes | ||
calculateVertices(attribute) { | ||
calculatePositions(attribute) { | ||
const vertices = flattenDeep(this.state.groupedVertices); | ||
@@ -113,0 +113,0 @@ attribute.value = new Float32Array(vertices); |
@@ -26,4 +26,4 @@ // Copyright (c) 2015 Uber Technologies, Inc. | ||
const ATTRIBUTES = { | ||
positions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'}, | ||
colors: {size: 4, '0': 'red', '1': 'green', '2': 'blue', '3': 'alpha'} | ||
instancePositions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'}, | ||
instanceColors: {size: 4, '0': 'red', '1': 'green', '2': 'blue', '3': 'alpha'} | ||
}; | ||
@@ -62,4 +62,4 @@ | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
positions: {update: this.calculatePositions}, | ||
colors: {update: this.calculateColors} | ||
instancePositions: {update: this.calculateInstancePositions}, | ||
instanceColors: {update: this.calculateInstanceColors} | ||
}); | ||
@@ -122,3 +122,3 @@ | ||
calculatePositions(attribute, numInstances) { | ||
calculateInstancePositions(attribute, numInstances) { | ||
const {unitWidth, unitHeight, width, height} = this.props; | ||
@@ -137,3 +137,3 @@ const {numCol} = this.state; | ||
calculateColors(attribute) { | ||
calculateInstanceColors(attribute) { | ||
const {data, unitWidth, unitHeight, width, height} = this.props; | ||
@@ -140,0 +140,0 @@ const {numCol, numRow} = this.state; |
@@ -22,8 +22,9 @@ // Copyright (c) 2015 Uber Technologies, Inc. | ||
import Layer from '../../layer'; | ||
import {Model, Program, Geometry} from 'luma.gl'; | ||
import {Model, Program, Geometry, CylinderGeometry} from 'luma.gl'; | ||
const glslify = require('glslify'); | ||
const ATTRIBUTES = { | ||
positions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'}, | ||
colors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'} | ||
instancePositions: {size: 2, '0': 'x', '1': 'y'}, | ||
instanceElevations: {size: 1, '0': 'z'}, | ||
instanceColors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'} | ||
}; | ||
@@ -48,3 +49,3 @@ | ||
dotRadius: 10, | ||
elevation: 0, | ||
elevation: 100, | ||
...opts | ||
@@ -62,4 +63,5 @@ }); | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
positions: {update: this.calculatePositions}, | ||
colors: {update: this.calculateColors} | ||
instancePositions: {update: this.calculateInstancePositions}, | ||
instanceElevations: {update: this.calculateInstanceElevations}, | ||
instanceColors: {update: this.calculateInstanceColors} | ||
}); | ||
@@ -76,7 +78,6 @@ | ||
if (dataChanged || viewportChanged) { | ||
attributeManager.invalidate('positions'); | ||
this.calculateRadiusAndAngle(); | ||
} | ||
if (dataChanged) { | ||
attributeManager.invalidate('colors'); | ||
attributeManager.invalidateAll(); | ||
} | ||
@@ -86,15 +87,33 @@ } | ||
getModel(gl) { | ||
const NUM_SEGMENTS = 6; | ||
const PI2 = Math.PI * 2; | ||
const geometry = new CylinderGeometry({ | ||
id: this.props.id, | ||
radius: 1, | ||
topRadius: 1, | ||
bottomRadius: 1, | ||
topCap: true, | ||
bottomCap: true, | ||
height: 1, | ||
nradial: 6, | ||
nvertical: 1 | ||
}); | ||
let vertices = []; | ||
for (let i = 0; i < NUM_SEGMENTS; i++) { | ||
vertices = [ | ||
...vertices, | ||
Math.cos(PI2 * i / NUM_SEGMENTS), | ||
Math.sin(PI2 * i / NUM_SEGMENTS), | ||
0 | ||
]; | ||
} | ||
// const NUM_SEGMENTS = 6; | ||
// const PI2 = Math.PI * 2; | ||
// let vertices = []; | ||
// for (let i = 0; i < NUM_SEGMENTS; i++) { | ||
// vertices = [ | ||
// ...vertices, | ||
// Math.cos(PI2 * i / NUM_SEGMENTS), | ||
// Math.sin(PI2 * i / NUM_SEGMENTS), | ||
// 0 | ||
// ]; | ||
// } | ||
// const geometry = new Geometry({ | ||
// id: this.props.id, | ||
// drawMode: 'TRIANGLE_FAN', | ||
// vertices: new Float32Array(vertices) | ||
// }); | ||
return new Model({ | ||
@@ -106,12 +125,9 @@ program: new Program(gl, { | ||
}), | ||
geometry: new Geometry({ | ||
id: this.props.id, | ||
drawMode: 'TRIANGLE_FAN', | ||
vertices: new Float32Array(vertices) | ||
}), | ||
geometry, | ||
instanced: true | ||
// indexed: true | ||
}); | ||
} | ||
calculatePositions(attribute) { | ||
calculateInstancePositions(attribute) { | ||
const {data} = this.props; | ||
@@ -123,3 +139,2 @@ const {value, size} = attribute; | ||
value[i + 1] = hexagon.centroid.y; | ||
value[i + 2] = 0; | ||
i += size; | ||
@@ -129,4 +144,14 @@ } | ||
calculateColors(attribute) { | ||
calculateInstanceElevations(attribute) { | ||
const {data} = this.props; | ||
const {value, size} = attribute; | ||
let i = 0; | ||
for (const hexagon of data) { | ||
value[i + 0] = hexagon.elevation || 0; | ||
i += size; | ||
} | ||
} | ||
calculateInstanceColors(attribute) { | ||
const {data} = this.props; | ||
const {value} = attribute; | ||
@@ -165,5 +190,6 @@ let i = 0; | ||
// Calculate angle that the perpendicular hexagon vertex axis is tilted | ||
angle: Math.acos(dx / dxy) * -Math.sign(dy), | ||
angle: Math.acos(dx / dxy) * -Math.sign(dy) + Math.PI / 2, | ||
// Allow user to fine tune radius | ||
radius: dxy / 2 * Math.min(1, this.props.dotRadius) | ||
radius: dxy / 2 * Math.min(1, this.props.dotRadius), | ||
elevation: this.props.elevation | ||
}); | ||
@@ -170,0 +196,0 @@ |
@@ -26,4 +26,4 @@ // Copyright (c) 2015 Uber Technologies, Inc. | ||
const ATTRIBUTES = { | ||
positions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'}, | ||
colors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'} | ||
instancePositions: {size: 3, '0': 'x', '1': 'y', '2': 'unused'}, | ||
instanceColors: {size: 3, '0': 'red', '1': 'green', '2': 'blue'} | ||
}; | ||
@@ -58,4 +58,4 @@ | ||
attributeManager.addInstanced(ATTRIBUTES, { | ||
positions: {update: this.calculatePositions}, | ||
colors: {update: this.calculateColors} | ||
instancePositions: {update: this.calculateInstancePositions}, | ||
instanceColors: {update: this.calculateInstanceColors} | ||
}); | ||
@@ -109,3 +109,3 @@ } | ||
calculatePositions(attribute) { | ||
calculateInstancePositions(attribute) { | ||
const {data} = this.props; | ||
@@ -122,3 +122,3 @@ const {value, size} = attribute; | ||
calculateColors(attribute) { | ||
calculateInstanceColors(attribute) { | ||
const {data} = this.props; | ||
@@ -125,0 +125,0 @@ const {value, size} = attribute; |
@@ -114,3 +114,3 @@ // Copyright (c) 2015 Uber Technologies, Inc. | ||
try { | ||
gl = createGLContext(canvas); | ||
gl = createGLContext(canvas, {preserveDrawingBuffer: true}); | ||
} catch (error) { | ||
@@ -140,3 +140,3 @@ this.props.onInitializationFailed(error); | ||
const pickedModels = scene.pickModels(gl, {camera, x, y}); | ||
const pickedModels = scene.pickModels(gl, {camera, x: x * 2, y: y * 2}); | ||
@@ -143,0 +143,0 @@ return pickedModels; |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
3063590
53505