<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<title>VueLayers UMD</title>
<!-- include Vue -->
<script src="https://u...content-available-to-author-only...g.com/vue/dist/vue.js"></script>
<!-- include OpenLayers -->
<script src="https://u...content-available-to-author-only...g.com/openlayers/dist/ol.js"></script>
<!-- include UMD VueLayers build -->
<link rel="stylesheet" href="https://u...content-available-to-author-only...g.com/vuelayers/lib/style.css">
<script src="https://u...content-available-to-author-only...g.com/vuelayers/lib/index.umd.js"></script>
<style>
html, body, #app {
width: 100%;
height: 100%;
margin: 0;
padding: 0;
box-sizing: border-box;
}
body * {
box-sizing: border-box;
}
</style>
</head>
<body>
<div id="app">
<div>
<vl-map :load-tiles-while-animating="true"
:load-tiles-while-interacting="true"
data-projection="EPSG:4326">
<vl-view :zoom="zoom"
:center="center"
:max-zoom="maxZoom"
:min-zoom="minZoom"
:rotation="rotation"></vl-view>
<vl-layer-tile>
<vl-source-xyz :url="'/map/{z}/{x}/{y}'"></vl-source-xyz>
</vl-layer-tile>
<vl-layer-vector>
<vl-source-vector>
<vl-feature v-for="f in features" :key="f.id">
<vl-geom-point :coordinates="f.geometry.coordinates"></vl-geom-point>
<vl-style-box>
<vl-style-text :text="_fommatText(f)"
font="bold 24px Arial"
text-align="end"
text-baseline="middle">
<vl-style-stroke :width="3"
color="rgba(250,0,0,0.8)"></vl-style-stroke>
<vl-style-fill :color="f.properties.color"></vl-style-fill>
</vl-style-text>
<vl-style-icon src="/Scripts/VueLayers/dot.png"
cross-origin="anonymous"
:color="f.properties.color"></vl-style-icon>
</vl-style-box>
</vl-feature>
</vl-source-vector>
</vl-layer-vector>
<vl-layer-vector>
<vl-source-vector ident="draw-target" ></vl-source-vector>
<vl-style-box>
<vl-style-text text=" how to bin text by data?"
font="bold 25px Arial"
text-align="end"
text-baseline="middle">
<vl-style-stroke color="red" :width="3"></vl-style-stroke>
<vl-style-fill color="yellow"></vl-style-fill>
</vl-style-text>
<vl-style-icon src="/Scripts/VueLayers/dot.png"
cross-origin="anonymous"
color="yellow"></vl-style-icon>
</vl-style-box>
</vl-layer-vector>
<vl-interaction-draw source="draw-target" type="Point"></vl-interaction-draw>
<vl-interaction-snap source="draw-target"></vl-interaction-snap>
<vl-interaction-modify source="draw-target"></vl-interaction-modify>
</vl-map>
</div>
<div>
<button @@click="test">test</button>
</div>
</div>
<script>
// all input/output coordinates, GeoJSON features in EPSG:4326 projection
Vue.use(VueLayers, {
dataProjection: 'EPSG:4326',
})
var app = new Vue({
el: '#app',
data: {
center: [37.41, 8.82],
rotation: 0,
zoom: 5,
maxZoom: 5,
minZoom: 5,
features: [
{
id: "d45bdba2-84b7-46d9-80a0-64b78c67acd1",
type: "Feature",
geometry: {
type: 'Point',
coordinates: [37.41, 15.82],
},
properties: {
name: "Point 1",
color: 'yellow',
value: 100,
},
},
{
id: "d45bdba2-84b7-46d9-80a0-64b78c67acd2",
type: "Feature",
geometry: {
type: 'Point',
coordinates: [30.41, 10.82],
},
properties: {
name: "Point 2",
color: 'yellow',
value: 50,
},
},
{
id: "d45bdba2-84b7-46d9-80a0-64b78c67acd3",
type: "Feature",
geometry: {
type: 'Point',
coordinates: [47.41, 15.82],
},
properties: {
name: "Point 3",
color: 'yellow',
value: 0,
},
},
],
},
methods: {
_fommatText(f) {
return ` ${f.properties.name}
${f.properties.value}%`;
},
test() {
setInterval(() => {
for (var i = 0; i < this.features.length; i++) {
let color = ["blue", "yellow", "green", "pink"][Math.ceil(Math.random() * 100) % 4];
let value = Math.ceil(Math.random() * 100);
this.features[i].properties.color = color;
this.features[i].properties.value = value;
}
}, 1000);
}
},
})
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <title>VueLayers UMD</title>
    <!-- include Vue -->
    <script src="https://u...content-available-to-author-only...g.com/vue/dist/vue.js"></script>
    <!-- include OpenLayers -->
    <script src="https://u...content-available-to-author-only...g.com/openlayers/dist/ol.js"></script>
    <!-- include UMD VueLayers build -->
    <link rel="stylesheet" href="https://u...content-available-to-author-only...g.com/vuelayers/lib/style.css">
    <script src="https://u...content-available-to-author-only...g.com/vuelayers/lib/index.umd.js"></script>
    <style>
        html, body, #app {
            width: 100%;
            height: 100%;
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

            body * {
                box-sizing: border-box;
            }
    </style>
</head>
<body>
    <div id="app">
        <div>
            <vl-map :load-tiles-while-animating="true"
                    :load-tiles-while-interacting="true"
                    data-projection="EPSG:4326">
                <vl-view :zoom="zoom"
                         :center="center"
                         :max-zoom="maxZoom"
                         :min-zoom="minZoom"
                         :rotation="rotation"></vl-view>

                <vl-layer-tile>
                    <vl-source-xyz :url="'/map/{z}/{x}/{y}'"></vl-source-xyz>
                </vl-layer-tile>

                <vl-layer-vector>
                    <vl-source-vector>
                        <vl-feature v-for="f in features" :key="f.id">
                            <vl-geom-point :coordinates="f.geometry.coordinates"></vl-geom-point>
                            <vl-style-box>
                                <vl-style-text :text="_fommatText(f)"
                                               font="bold 24px Arial"
                                               text-align="end"
                                               text-baseline="middle">
                                    <vl-style-stroke :width="3"
                                                     color="rgba(250,0,0,0.8)"></vl-style-stroke>
                                    <vl-style-fill :color="f.properties.color"></vl-style-fill>
                                </vl-style-text>
                                <vl-style-icon src="/Scripts/VueLayers/dot.png"
                                               cross-origin="anonymous"
                                               :color="f.properties.color"></vl-style-icon>
                            </vl-style-box>
                        </vl-feature>
                    </vl-source-vector>
                </vl-layer-vector>

                <vl-layer-vector>
                    <vl-source-vector ident="draw-target" ></vl-source-vector>
                    <vl-style-box>
                        <vl-style-text text=" how to bin text by data?"
                                       font="bold 25px Arial"
                                       text-align="end"
                                       text-baseline="middle">
                            <vl-style-stroke color="red" :width="3"></vl-style-stroke>
                            <vl-style-fill color="yellow"></vl-style-fill>
                        </vl-style-text>
                        <vl-style-icon src="/Scripts/VueLayers/dot.png"
                                       cross-origin="anonymous"
                                       color="yellow"></vl-style-icon>
                    </vl-style-box>
                </vl-layer-vector>
                <vl-interaction-draw source="draw-target" type="Point"></vl-interaction-draw>
                <vl-interaction-snap source="draw-target"></vl-interaction-snap>
                <vl-interaction-modify source="draw-target"></vl-interaction-modify>

            </vl-map>
        </div>
        <div>
            <button @@click="test">test</button>
        </div>
    </div>

    <script>
        // all input/output coordinates, GeoJSON features in EPSG:4326 projection
        Vue.use(VueLayers, {
            dataProjection: 'EPSG:4326',
        })

        var app = new Vue({
            el: '#app',
            data: {
                center: [37.41, 8.82],
                rotation: 0,
                zoom: 5,
                maxZoom: 5,
                minZoom: 5,
                features: [
                    {
                        id: "d45bdba2-84b7-46d9-80a0-64b78c67acd1",
                        type: "Feature",
                        geometry: {
                            type: 'Point',
                            coordinates: [37.41, 15.82],
                        },
                        properties: {
                            name: "Point 1",
                            color: 'yellow',
                            value: 100,
                        },
                    },
                    {
                        id: "d45bdba2-84b7-46d9-80a0-64b78c67acd2",
                        type: "Feature",
                        geometry: {
                            type: 'Point',
                            coordinates: [30.41, 10.82],
                        },
                        properties: {
                            name: "Point 2",
                            color: 'yellow',
                            value: 50,
                        },
                    },
                    {
                        id: "d45bdba2-84b7-46d9-80a0-64b78c67acd3",
                        type: "Feature",
                        geometry: {
                            type: 'Point',
                            coordinates: [47.41, 15.82],
                        },
                        properties: {
                            name: "Point 3",
                            color: 'yellow',
                            value: 0,
                        },
                    },
                ],
            },
            methods: {
                _fommatText(f) {
                    return `  ${f.properties.name}
       ${f.properties.value}%`;
                },
                test() {
                    setInterval(() => {
                        for (var i = 0; i < this.features.length; i++) {
                            let color = ["blue", "yellow", "green", "pink"][Math.ceil(Math.random() * 100) % 4];
                            let value = Math.ceil(Math.random() * 100);
                            this.features[i].properties.color = color;
                            this.features[i].properties.value = value;
                        }
                    }, 1000);
                }
            },
        })
    </script>
</body>
</html>