- Accessible Map
- Advanced Mapbox Vector Tiles
- 高级地图定位
- 地图加载 GIF 动图
- ArcGIS REST Feature Service
- Attributions
- 波段对比度调节
- Bing Maps
- Box Selection
- Canvas Tiles
- CartoDB source example
- Change Tile Layer Style
- Cloud Optimized GeoTIFF (COG)
- Cloud Optimized GeoTIFF (COG) from a Blob
- Clustered Features
- Color Manipulation
- Constrained Extent
- Constrained Zoom
- Custom Animation
- Custom Canvas Tiles
- 自定义圆形渲染
- 自定义控件
- 自定义拖拽上传展示数据(KMZ)
- 自定义拖拽上传展示数据 (MVT 预览)
- 自定义触发器渲染
- 自定义交互
- 地图自定义 dom 元素(element)
- 自定义鹰眼
- 自定义面状图形要素样式
- 自定义瓦片 WMS
- 自定义提示信息
- d3 集成
- 数据瓦片
- 设备定位
- 拖拽加载数据
- 拖拽 Image Vector
- 拖拽,旋转和缩放
- 绘制和修改图形要素(Features)
- 绘制和编辑测地线(Geodesic)圆
- 绘制图形要素(Feature)
- 绘制规则图形
- 动态聚合
- 动画展示数据
- 地震位置聚合图
- 地震位置热力图
- 渲染 KML 中的地震数据
- 自定义图形渲染地震数据
- 可编辑的 ArcGIS REST 图形要素服务
- EPSG:4326
- 导出 PDF 示例
- 范围(Extent)交互
- 外部地图
- 使用 WebGL 过滤图形要素
- 航班飞行动画
- Fractal 渲染
- 自由绘制
- 全屏控件
- 带有扩展element的全屏控件
- 全屏拖拽,旋转,缩放
- Geographic Coordinates
- Geographic Editing
- GeoJSON
- 集成 geojson-vt
- 地理位置
- GeoTIFF 瓦片金字塔
- GeoTIFF with Overviews
- GPX 数据
- 高 DPI WMTS
- 点击容许偏差
- Icon 比例
- Icon 颜色
- Icon 位置修改
- Icon 像素操作
- Icon Sprites with WebGL
- Icon 渲染
- IGC 数据
- IGN WMTS
- IIIF 影像 API
- ArcGIS 图像地图服务
- 图片过滤
- 图像载入事件
- 图像重投影
- 即时渲染 (地理)
- 插值
- 集成 JSTS
- KML
- Layer 裁剪
- 图层组
- 图层 最小/最大 分辨率
- 图层透明度
- 图层鼠标透视
- 图层卷帘
- 图层卷帘 (WebGL)
- 图层层级(Z-Index)
- 图层缩放限制
- 懒加载资源
- 限制图层范围
- 线段箭头
- 载入中旋转动画
- 局部的 OpenStreetMap
- 鼠标放大镜效果
- 地图打印(导出)
- 地图经纬网格
- 地图链接地址
- Mapbox 矢量图层
- Mapbox 矢量瓦片
- Mapbox-gl 图层
- MapGuide Untiled
- 地图点图标动画
- 测量
- 使用矢量样式测量
- 修改图形要素(Features)
- 修改图形要素测试
- 显示鼠标位置
- 地图平移(拖拽)结束事件
- 定位控件
- NDVI from a Sentinel 2 COG
- 动态颜色斜率 NDVI
- NDVI+NDWI from two 16-bit COGs
- OGC 地图瓦片
- OGC 地图瓦片 (地理)
- OGC 矢量瓦片
- OpenStreetMap 重投影
- 带有比例尺控件的 OpenStreetMap 重投影
- OSM 矢量瓦片
- OSM XML
- 覆盖物(Overlay)
- 鹰眼地图控件
- 页面滚动
- 拖拽和页面滚动
- Permalink
- Pinch Zoom
- Popup
- Preload Tiles
- 按比例导出地图
- 投影和比例尺
- 栅格重投影
- 栅格资源
- 区域增长
- Regular Shapes
- Render geometries to a canvas
- Rendering 16-bit NumpyTiles
- Reprojection with EPSG.io Search
- Reusable Source
- Rich Text Labels
- Scale and Rotate using Modify Interaction
- Scale Line
- Sea Level
- Sea Level (with WebGL)
- Select Features
- Select Features by Hover
- Select multiple Features
- Semi-Transparent Layer
- Shaded Relief
- Shaded Relief (with WebGL)
- Shared Views
- Simple Map
- Single Image WMS
- Single Image WMS with Proj4js
- Smoothing lines using Chaikins algorithm
- Snap Interaction
- Sphere Mollweide
- Stamen Tiles
- Static Image
- Street Labels
- Style renderer
- Styling feature with CanvasGradient or CanvasPattern
- SVG Layer
- Synthetic Lines
- Synthetic Points
- Teleporting Maps
- Tile Load Events
- Tile Transitions
- Tiled ArcGIS MapServer
- Tiled WMS
- Tiled WMS Wrapping
- TileJSON
- Timezones in KML
- Tissot Indicatrix
- TopoJSON
- topolis integration
- Tracing around a polygon
- Translate Features
- turf.js
- UTFGrid
- Vector Clipping Layer
- Vector Image Layer
- Vector Label Decluttering
- Vector Labels
- Vector Labels - Justify Text
- Vector Layer
- Vector Layer Hit Detection
- Vector Tile Info
- Vector Tile Selection
- Vector tiles created from a Mapbox Style object
- Vector tiles in EPSG:4326
- Vector tiles rendered in an offscreen canvas
- View Animation
- View Min-Zoom
- View Padding
- View Rotation
- WebGL points layer
- WebGL Tile Layer Styles
- WebGL Tiles
- WebGL Vector Layer
- WFS
- WFS - GetFeature
- WFS with geographic coordinates
- Wind Arrows
- WKB
- WKT
- WMS 512x256 Tiles
- WMS Capabilities Parsing
- WMS GetFeatureInfo (Image Layer)
- WMS GetFeatureInfo (Layers)
- WMS GetFeatureInfo (Tile Layer)
- WMS GetLegendGraphic
- WMS 时序渲染
- 无投影 WMS
- WMTS
- WMTS Capabilities 解析
- 从 Capabilities 加载 WMTS
- WMTS 瓦片转换
- XYZ
- XYZ Esri
- XYZ 视网膜瓦片
- 缩放滑块
- Zoomify
Sea Level (with WebGL)
Render sea level at different elevations
The style
property of a WebGL tile layer accepts a color
expression that can be used to modify pixel values before rendering. Here, RGB tiles representing elevation data are loaded and rendered so that values at or below sea level are blue, and values above sea level are transparent. The color
expression operates on normalized pixel values ranging from 0 to 1. The band
operator is used to select normalized values from a single band.
After converting the normalized RGB values to elevation, the case
expression is used to pick colors to apply at a given elevation. Instead of using constant numeric values as the stops in the colors array, the var
operator allows you to use a value that can be modified by your application. When the user drags the sea level slider, the layer.updateStyleVariables()
function is called to update the level
style variable with the value from the slider.
main.js
import 'ol/ol.css';
import Map from 'ol/Map';
import TileLayer from 'ol/layer/WebGLTile';
import View from 'ol/View';
import XYZ from 'ol/source/XYZ';
import {fromLonLat} from 'ol/proj';
const key = 'Get your own API key at https://www.maptiler.com/cloud/';
const attributions =
'<a href="https://www.maptiler.com/copyright/" target="_blank">© MapTiler</a> ' +
'<a href="https://www.openstreetmap.org/copyright" target="_blank">© OpenStreetMap contributors</a>';
// band math operates on normalized values from 0-1
// so we scale by 255 to align with the elevation formula
// from https://cloud.maptiler.com/tiles/terrain-rgb/
const elevation = [
'+',
-10000,
[
'*',
0.1 * 255,
[
'+',
['*', 256 * 256, ['band', 1]],
['+', ['*', 256, ['band', 2]], ['band', 3]],
],
],
];
const layer = new TileLayer({
opacity: 0.6,
source: new XYZ({
url:
'https://api.maptiler.com/tiles/terrain-rgb/{z}/{x}/{y}.png?key=' + key,
maxZoom: 10,
tileSize: 512,
crossOrigin: 'anonymous',
}),
style: {
variables: {
level: 0,
},
color: [
'case',
// use the `level` style variable to determine the color
['<=', elevation, ['var', 'level']],
[139, 212, 255, 1],
[139, 212, 255, 0],
],
},
});
const map = new Map({
target: 'map',
layers: [
new TileLayer({
source: new XYZ({
url: 'https://api.maptiler.com/maps/streets/{z}/{x}/{y}.png?key=' + key,
attributions: attributions,
crossOrigin: 'anonymous',
tileSize: 512,
}),
}),
layer,
],
view: new View({
center: fromLonLat([-122.3267, 37.8377]),
zoom: 11,
}),
});
const control = document.getElementById('level');
const output = document.getElementById('output');
const listener = function () {
output.innerText = control.value;
layer.updateStyleVariables({level: parseFloat(control.value)});
};
control.addEventListener('input', listener);
control.addEventListener('change', listener);
output.innerText = control.value;
const locations = document.getElementsByClassName('location');
for (let i = 0, ii = locations.length; i < ii; ++i) {
locations[i].addEventListener('click', relocate);
}
function relocate(event) {
const data = event.target.dataset;
const view = map.getView();
view.setCenter(fromLonLat(data.center.split(',').map(Number)));
view.setZoom(Number(data.zoom));
}
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Sea Level (with WebGL)</title>
<!-- Pointer events polyfill for old browsers, see https://caniuse.com/#feat=pointer -->
<script src="https://unpkg.com/elm-pep"></script>
<!-- The line below is only needed for old environments like Internet Explorer and Android 4.x -->
<script src="https://cdn.polyfill.io/v3/polyfill.min.js?features=fetch,requestAnimationFrame,Element.prototype.classList,URL,TextDecoder,Number.isInteger"></script>
<style>
.map {
width: 100%;
height:400px;
}
#level {
display: inline-block;
width: 150px;
vertical-align: text-bottom;
}
a.location {
cursor: pointer;
}
#map {
background: #8bd4ff;
}
</style>
</head>
<body>
<div id="map" class="map"></div>
<label>
Sea level
<input id="level" type="range" min="0" max="100" value="1"/>
+<span id="output"></span> m
</label>
<br>
Go to
<a class="location" data-center="-122.3267,37.8377" data-zoom="11">San Francisco</a>,
<a class="location" data-center="-73.9338,40.6861" data-zoom="11">New York</a>,
<a class="location" data-center="72.9481,18.9929" data-zoom="11">Mumbai</a>, or
<a class="location" data-center="120.831,31.160" data-zoom="9">Shanghai</a>
<script src="main.js"></script>
</body>
</html>
package.json
{
"name": "webgl-sea-level",
"dependencies": {
"ol": "7.1.0"
},
"devDependencies": {
"parcel": "^2.0.0-beta.1"
},
"scripts": {
"start": "parcel index.html",
"build": "parcel build --public-url . index.html"
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论