写实花头,版不规则分布向日葵与物理对齐修复。
// ==UserScript==
// @name 💙💛Ukrainian Flag & Sunflower (Ctrl+Shift+U)
// @namespace tampermonkey.net
// @version 12.6
// @description 写实花头,版不规则分布向日葵与物理对齐修复。
// @author 邢智轩 (from China)
// @match *://*/*
// @grant none
// @license MIT
// ==/UserScript==
(function() {
'use strict';
let isTerminated = false;
function injectBadge() {
if (document.getElementById('ua-waving-badge-root')) return;
const host = document.createElement('div');
host.id = 'ua-waving-badge-root';
host.style.cssText = `
position: fixed !important;
bottom: 60px !important;
left: 60px !important;
z-index: 2147483647 !important;
pointer-events: none !important;
transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1) !important;
opacity: 0;
transform: translateX(-20px) scale(0.9);
`;
document.documentElement.appendChild(host);
const shadow = host.attachShadow({mode: 'closed'});
const tridentSvg = ``;
shadow.innerHTML = `
<style>
.container {
position: relative;
width: 320px;
height: 200px;
display: flex;
align-items: flex-end;
}
/* --- 黄金旗杆 (12.5 经典质感) --- */
.pole-system {
position: absolute;
left: 40px;
bottom: 20px;
height: 160px;
display: flex;
flex-direction: column;
align-items: center;
z-index: 100;
}
.pole-top {
width: 14px;
height: 14px;
background: radial-gradient(circle at 35% 35%, #fff9e6 0%, #ffd700 45%, #8b6914 100%);
border-radius: 50%;
box-shadow: 0 2px 5px rgba(0,0,0,0.5);
margin-bottom: -2px;
}
.pole-body {
width: 8px;
height: 100%;
background: linear-gradient(to right, #4d3d00 0%, #8b6914 15%, #ffd700 40%, #fff9e6 55%, #ffd700 70%, #8b6914 85%, #4d3d00 100%);
border-radius: 0 0 4px 4px;
}
/* --- 旗帜:物理对齐修正 --- */
.flag-wrapper {
position: absolute;
left: 44px; /* 锁死在旗杆边缘 */
top: 35px; /* 绝不超出旗杆顶球 */
width: 150px;
height: 90px;
perspective: 1200px;
z-index: 50;
}
.flag {
width: 100%;
height: 100%;
transform-style: preserve-3d;
transform-origin: left center;
animation: cinematic-wave 6s infinite ease-in-out;
}
.fabric {
position: absolute;
inset: 0;
background: linear-gradient(to bottom, #0057B7 50%, #FFD700 50%);
border-radius: 0 4px 4px 0;
overflow: hidden;
display: flex;
align-items: center;
justify-content: center;
box-shadow: inset 12px 0 15px rgba(0,0,0,0.5);
}
.shading {
position: absolute;
inset: 0;
background: linear-gradient(90deg, rgba(0,0,0,0.15) 0%, rgba(255,255,255,0.2) 25%, rgba(0,0,0,0.3) 50%, rgba(255,255,255,0.2) 75%, rgba(0,0,0,0.15) 100%);
background-size: 200% 100%;
animation: move-shade 4s infinite linear;
mix-blend-mode: overlay;
}
.trident { width: 30px; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.4)); transform: translateZ(10px); }
/* --- 18.0 版向日葵花头核心 --- */
.garden {
position: absolute;
left: 0;
bottom: 0;
width: 280px;
height: 85px;
z-index: 150;
pointer-events: none;
}
.sunflower {
position: absolute;
bottom: 0;
display: flex;
flex-direction: column;
align-items: center;
transform-origin: bottom center;
animation: flower-sway 5s infinite ease-in-out;
}
.flower-head { width: 24px; height: 24px; position: relative; }
/* 还原 18.0 花瓣逻辑 */
.petals {
position: absolute; inset: 0;
background: radial-gradient(ellipse at center, #FFD700 35%, transparent 75%),
repeating-conic-gradient(from 0deg, #FFC107 0deg 20deg, #F57F17 20deg 40deg);
border-radius: 50%;
}
.petals::before {
content: ''; position: absolute; inset: -3px;
background: repeating-conic-gradient(from 10deg, transparent 0deg 15deg, #FFD700 15deg 35deg, transparent 35deg 40deg);
border-radius: 50%; mask: radial-gradient(circle, black 40%, transparent 85%);
}
/* 还原 18.0 花芯逻辑 */
.core {
position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
width: 8px; height: 8px; background: #3E2723;
border-radius: 50%; box-shadow: inset 0 0 3px #000; z-index: 2;
}
.stem {
width: 2.5px;
background: linear-gradient(to right, #1B5E20, #388E3C, #1B5E20);
border-radius: 2px;
position: relative;
}
.sf-leaf {
position: absolute; width: 9px; height: 6px;
background: radial-gradient(at 20% 20%, #66BB6A, #1B5E20);
border-radius: 1px 80% 1px 80%;
}
.leaf-L { left: -8px; top: 12px; transform: rotate(-20deg); }
.leaf-R { right: -8px; top: 18px; transform: scaleX(-1) rotate(-20deg); }
/* --- 21.5 版群落分布 --- */
.sf1 { left: 18px; transform: scale(0.6); animation-delay: -0.2s; } .sf1 .stem { height: 35px; }
.sf2 { left: 35px; transform: scale(0.85); animation-delay: -1.5s; z-index: 152; } .sf2 .stem { height: 58px; }
.sf3 { left: 48px; transform: scale(0.55); animation-delay: -2.8s; } .sf3 .stem { height: 28px; }
.sf4 { left: 85px; transform: scale(0.7); animation-delay: -3.3s; } .sf4 .stem { height: 45px; }
.sf5 { left: 110px; transform: scale(0.75); animation-delay: -0.9s; } .sf5 .stem { height: 52px; }
.sf6 { left: 155px; transform: scale(0.6); animation-delay: -4.1s; } .sf6 .stem { height: 40px; }
.sf7 { left: 180px; transform: scale(0.8); animation-delay: -2.5s; } .sf7 .stem { height: 62px; }
.sf8 { left: 215px; transform: scale(0.65); animation-delay: -1.2s; } .sf8 .stem { height: 38px; }
.sf9 { left: 25px; bottom: 8px; transform: scale(0.45); animation-delay: -1.1s; z-index: 160; } .sf9 .stem { height: 18px; }
.sf10 { left: 70px; bottom: 5px; transform: scale(0.4); animation-delay: -3.7s; z-index: 160; } .sf10 .stem { height: 15px; }
.sf11 { left: 135px; bottom: 10px; transform: scale(0.5); animation-delay: -0.5s; z-index: 160; } .sf11 .stem { height: 22px; }
.sf12 { left: 195px; bottom: 4px; transform: scale(0.4); animation-delay: -2.9s; z-index: 160; } .sf12 .stem { height: 16px; }
@keyframes cinematic-wave {
0%, 100% { transform: rotateY(12deg) rotateX(2deg); }
50% { transform: rotateY(26deg) rotateX(-2deg); }
}
@keyframes flower-sway {
0%, 100% { transform: rotate(-3deg); }
50% { transform: rotate(3deg); }
}
@keyframes move-shade { from { background-position: 0% 0; } to { background-position: 200% 0; } }
</style>
<div class="container">
<div class="pole-system">
<div class="pole-top"></div>
<div class="pole-body"></div>
</div>
<div class="flag-wrapper">
<div class="flag">
<div class="fabric">
<div class="shading"></div>
<img src="${tridentSvg}" class="trident" />
</div>
</div>
</div>
<div class="garden">
<!-- 保持关键叶子分布 -->
<div class="sunflower sf1"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"><div class="sf-leaf leaf-L"></div></div></div>
<div class="sunflower sf2"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"><div class="sf-leaf leaf-R"></div></div></div>
<div class="sunflower sf3"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"></div></div>
<div class="sunflower sf4"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"><div class="sf-leaf leaf-L"></div></div></div>
<div class="sunflower sf5"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"></div></div>
<div class="sunflower sf6"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"></div></div>
<div class="sunflower sf7"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"><div class="sf-leaf leaf-R"></div></div></div>
<div class="sunflower sf8"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"></div></div>
<div class="sunflower sf9"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"></div></div>
<div class="sunflower sf10"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"></div></div>
<div class="sunflower sf11"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"></div></div>
<div class="sunflower sf12"><div class="flower-head"><div class="petals"></div><div class="core"></div></div><div class="stem"></div></div>
</div>
</div>`;
requestAnimationFrame(() => {
host.style.opacity = '1';
host.style.transform = 'translateX(0) scale(1)';
});
}
window.addEventListener('keydown', (e) => {
if (e.ctrlKey && e.shiftKey && e.code === 'KeyU') {
const root = document.getElementById('ua-waving-badge-root');
if (root) {
root.style.opacity = '0';
root.style.transform = 'translateX(-20px) scale(0.9)';
setTimeout(() => { root.remove(); isTerminated = true; }, 800);
} else {
isTerminated = false;
injectBadge();
}
}
}, true);
injectBadge();
setInterval(() => { if(!isTerminated) injectBadge(); }, 3000);
})();