178 lines
4.1 KiB
HTML
178 lines
4.1 KiB
HTML
<!DOCTYPE html>
|
||
<html lang="zh">
|
||
<head>
|
||
<meta charset="UTF-8">
|
||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||
<title>lime-svg</title>
|
||
<style>
|
||
html,
|
||
body,
|
||
img,
|
||
div {
|
||
padding: 0;
|
||
margin: 0;
|
||
width: 100%;
|
||
height: 100%;
|
||
position: relative;
|
||
overflow: hidden;
|
||
pointer-events: none;
|
||
}
|
||
|
||
html,
|
||
body {
|
||
background-color: transparent;
|
||
}
|
||
|
||
#lime-icon {
|
||
transition: all 100ms;
|
||
}
|
||
|
||
#lime-icon.is-inherit {
|
||
-webkit-mask-image: var(--svg);
|
||
mask-image: var(--svg);
|
||
-webkit-mask-repeat: no-repeat;
|
||
mask-repeat: no-repeat;
|
||
-webkit-mask-size: 100% 100%;
|
||
mask-size: 100% 100%;
|
||
background-color: var(--color, transparent);
|
||
/* 设置背景颜色为--color的值,默认为透明 */
|
||
/* background-blend-mode: multiply; */
|
||
}
|
||
|
||
#lime-icon:not(.is-inherit) {
|
||
background: var(--svg) no-repeat;
|
||
background-size: 100% 100%;
|
||
background-color: transparent;
|
||
}
|
||
|
||
#lime-image {
|
||
mix-blend-mode: lighten;
|
||
}
|
||
</style>
|
||
</head>
|
||
<body>
|
||
<div id="lime-icon">
|
||
<img id="lime-image" />
|
||
</div>
|
||
<script type="text/javascript" src="uni.webview.1.5.5.js"></script>
|
||
<script>
|
||
const image = document.getElementById('lime-image');
|
||
const icon = document.getElementById('lime-icon');
|
||
let lastSrc = ''
|
||
|
||
function setSrc(src) {
|
||
if (lastSrc == src) return
|
||
lastSrc = src;
|
||
const _src = src.split('<svg')
|
||
if (_src.length > 1) {
|
||
src = (_src[0] == '' ? 'data:image/svg+xml,' : _src[0]) + encodeURIComponent('<svg' + _src[1])
|
||
}
|
||
// src = src.replace(/#/g, '%23').replace(/"/g, `'`)
|
||
|
||
|
||
image.src = src
|
||
// icon.style.setProperty('--svg', `url('${src}')`);
|
||
icon.style.setProperty('--svg', `url("${src}")`);
|
||
// icon.style.setProperty('--svg', `url(${src})`);
|
||
image.onload = (e) => {
|
||
emit('load', {
|
||
type: "load",
|
||
timeStamp: e.timeStamp,
|
||
detail: {
|
||
width: image.naturalWidth,
|
||
height: image.naturalHeight,
|
||
}
|
||
})
|
||
}
|
||
image.onerror = (e) => {
|
||
emit('error', {
|
||
type: "error",
|
||
timeStamp: e.timeStamp,
|
||
detail: {
|
||
width: image.naturalWidth,
|
||
height: image.naturalHeight,
|
||
}
|
||
})
|
||
}
|
||
}
|
||
|
||
function setStyle(style) {
|
||
if (typeof style === 'object') {
|
||
for (let [key, value] of Object.entries(style)) {
|
||
if (key == '--color') {
|
||
if (value) {
|
||
icon.classList.add('is-inherit')
|
||
} else {
|
||
value = 'black'
|
||
}
|
||
}
|
||
icon.style.setProperty(key, value);
|
||
}
|
||
}
|
||
}
|
||
|
||
function emit(event, data = {}) {
|
||
postMessage({
|
||
event,
|
||
data
|
||
});
|
||
};
|
||
|
||
function postMessage(data) {
|
||
uni.webView.postMessage({data})
|
||
|
||
// if (window.__uniapp_x_) {
|
||
// window.__uniapp_x_.postMessage(JSON.stringify(data))
|
||
// } else if (uni.webView.postMessage) {
|
||
// uni.webView.postMessage({
|
||
// data
|
||
// })
|
||
// }
|
||
};
|
||
|
||
// setStyle({
|
||
// color: 'red',
|
||
// })
|
||
// setSrc('https://api.iconify.design/bi/bell-fill.svg')
|
||
|
||
// 禁用所有事件
|
||
document.addEventListener('mousedown', function(event) {
|
||
event.stopImmediatePropagation();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
});
|
||
|
||
document.addEventListener('mouseup', function(event) {
|
||
event.stopImmediatePropagation();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
});
|
||
|
||
document.addEventListener('click', function(event) {
|
||
event.stopImmediatePropagation();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
emit('click')
|
||
});
|
||
|
||
document.addEventListener('keydown', function(event) {
|
||
event.stopImmediatePropagation();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
});
|
||
|
||
document.addEventListener('keyup', function(event) {
|
||
event.stopImmediatePropagation();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
});
|
||
|
||
document.addEventListener('keypress', function(event) {
|
||
event.stopImmediatePropagation();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
});
|
||
</script>
|
||
</body>
|
||
</html> |