From dadeb8bba593fa2fbee7a9f04743d94646baaa55 Mon Sep 17 00:00:00 2001 From: czc <1040398400@qq.com> Date: Mon, 5 Aug 2024 22:09:39 +0800 Subject: [PATCH] =?UTF-8?q?8.5=20=E7=9C=8B=E5=AE=8C=E4=BA=86BootScreen?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/App.jsx | 37 +++++++++++++++++++++++++---- src/containers/background/back.scss | 6 ++++- src/containers/background/index.jsx | 6 ++++- src/index.css | 5 +++- src/index.jsx | 2 ++ src/reducers/wallpaper.js | 8 ++++++- 6 files changed, 55 insertions(+), 9 deletions(-) diff --git a/src/App.jsx b/src/App.jsx index ddcf7a3b3..047ce37aa 100644 --- a/src/App.jsx +++ b/src/App.jsx @@ -58,6 +58,11 @@ function ErrorFallback({ error, resetErrorBoundary }) { Stop Code: {error.message} + {/* */} + {/* resetErrorBoundary应该是自定义的吧 */} @@ -72,6 +77,9 @@ function App() { const wall = useSelector((state) => state.wallpaper); const dispatch = useDispatch(); + // 这个函数的作用应该都是隐藏组件 几乎点击任何地方都会触发这个函数 + // 比如点击搜索按钮,事件的target.dataset.action为STARTSRC,就会弹出一个框,然后把其他的一些东西隐藏 + // 点击spotify,点击的target.dataset.action为spotify,然后下面的没有一个匹配的,就会把,一些开始弹窗什么的hide掉,如果有和下面匹配的,就弹出匹配的,然后其他的隐藏掉 const afterMath = (event) => { var ess = [ ["START", "STARTHID"], @@ -81,26 +89,32 @@ function App() { ["CALN", "CALNHIDE"], ["MENU", "MENUHIDE"], ]; + // console.log('afterMath'); var actionType = ""; try { actionType = event.target.dataset.action || ""; } catch (err) {} - + // getComputedStyle获取css属性和值,getPropertyValue获取这个--prefix css属性的值,有的地方有用到,搜索--prefix可以搜到一点,应该是为了特殊的过滤 var actionType0 = getComputedStyle(event.target).getPropertyValue( "--prefix", ); + // console.log(actionType); + // console.log(actionType0); ess.forEach((item, i) => { + // 这一部分是等于把ess中的操作都执行一边,用于hide一些东西 if (!actionType.startsWith(item[0]) && !actionType0.startsWith(item[0])) { + // console.log(item[1]); 这一行几乎会把所有的都答应出来,就是为了隐藏 dispatch({ type: item[1], }); } }); }; - + // 这是为了把window的鼠标右击事件先用afterMath处理一下,使得再弹出右键菜单时把什么开始栏,搜索栏,设置栏隐藏掉 window.oncontextmenu = (e) => { + // 点了邮件就隐藏,下面再按条件判断是否弹右键菜单 afterMath(e); e.preventDefault(); // dispatch({ type: 'GARBAGE'}); @@ -108,7 +122,7 @@ function App() { top: e.clientY, left: e.clientX, }; - + // e.target.dataset.menu只在桌面不为null,所以只在桌面触发 if (e.target.dataset.menu != null) { data.menu = e.target.dataset.menu; data.attr = e.target.attributes; @@ -121,14 +135,16 @@ function App() { }; window.onclick = afterMath; - + //页面加载完成触发onload 可能就是设置壁纸加载完成的作用 还不是很懂 window.onload = (e) => { dispatch({ type: "WALLBOOTED" }); }; - + // 作用就是5秒后在执行一次 loadSettings(); 和dispatch({ type: "WALLBOOTED" }); + // 因为window就是没有onstart这个属性的 useEffect(() => { if (!window.onstart) { loadSettings(); + // setTimeout是有返回值的,返回一个数字作为这个定时器的标识符 window.onstart = setTimeout(() => { // console.log("prematurely loading ( ノ ゚ー゚)ノ"); dispatch({ type: "WALLBOOTED" }); @@ -136,10 +152,21 @@ function App() { } }); + // useEffect(() => { + // console.log(wall); + // }, [wall]) + + + return (
+ {/* 应该是模拟开机的意思 用了z-index对其他元素进行覆盖,被覆盖元素的鼠标事件也被阻挡*/} + {/* 取消鼠标事件阻挡的方法 + 1. pointer-events: none; 这个属性告诉浏览器不要让元素及其子元素接收鼠标事件 + 2. 事件委托 在一个共同的父元素上监听事件 然后根据用事件对象的 target 属性来确定实际触发事件的元素*/} {!wall.booted ? : null} + {/* 锁屏 */} {wall.locked ? : null}
diff --git a/src/containers/background/back.scss b/src/containers/background/back.scss index 9ace564de..420b8cb49 100644 --- a/src/containers/background/back.scss +++ b/src/containers/background/back.scss @@ -23,6 +23,7 @@ z-index: 2; display: grid; place-items: center; + // 设置鼠标指针在悬停于该元素上时显示为一个进度指示器,通常是一个旋转的等待图标,表明正在执行一个后台操作或等待某个过程完成。 挺好玩的 手机端没这个属性 cursor: progress; } @@ -153,6 +154,7 @@ align-items: center; justify-content: center; } + // https://docs.microsoft.com/en-us/fluent-ui/web-components/components/progress-ring .progressRing circle { @@ -170,12 +172,14 @@ stroke-dasharray: 0.01px, 43.97px; transform: rotate(0deg); } + 50% { stroke-dasharray: 21.99px, 21.99px; transform: rotate(450deg); } + 100% { stroke-dasharray: 0.01px, 43.97px; transform: rotate(1080deg); } -} +} \ No newline at end of file diff --git a/src/containers/background/index.jsx b/src/containers/background/index.jsx index d35843e3b..577719cf0 100644 --- a/src/containers/background/index.jsx +++ b/src/containers/background/index.jsx @@ -18,11 +18,14 @@ export const Background = () => { ); }; +// 只有WALLRESTART和WALLSHUTDN会将booted设置成false 触发这个组件 +// 这两个动作也会将dir设置成 -1 +// dir为-1,就会触发下面的如果dir小于0,就给一个几秒后图片和圈圈都消失,然后触发WALLBOOTED这个动作 又将 booted: true, dir: 0, export const BootScreen = (props) => { const dispatch = useDispatch(); const wall = useSelector((state) => state.wallpaper); const [blackout, setBlackOut] = useState(false); - + // 如果dir小于0,就给一个几秒后图片和圈圈都消失,然后触发WALLBOOTED这个动作 useEffect(() => { if (props.dir < 0) { setTimeout(() => { @@ -40,6 +43,7 @@ export const BootScreen = (props) => { setBlackOut(false); setTimeout(() => { dispatch({ type: "WALLBOOTED" }); + //WALLBOOTED booted: true, dir: 0, }, 4000); }, 2000); } diff --git a/src/index.css b/src/index.css index f7e5936b8..5c04d50b8 100644 --- a/src/index.css +++ b/src/index.css @@ -150,9 +150,11 @@ i[data-flip="true"] { .dpShad { box-shadow: 0 0 6px rgba(0, 0, 0, 0.25); } + .mdShad { box-shadow: 0 0 8px rgba(41, 41, 41, 0.1); } + .ltShad { box-shadow: 0 1px 1px rgba(0, 0, 0, 0.25); } @@ -264,9 +266,10 @@ a { width: 100%; position: relative; height: 100%; + /* 这部分是用于设置子元素居中 */ display: flex; justify-content: center; align-items: center; background: #010001; color: white; -} +} \ No newline at end of file diff --git a/src/index.jsx b/src/index.jsx index 34d17a883..b07a785ef 100644 --- a/src/index.jsx +++ b/src/index.jsx @@ -7,6 +7,7 @@ import { Provider } from "react-redux"; const root = createRoot(document.getElementById("root")); root.render( + // 这个Suspense用于处理异步加载,当其子组件还在加载时,它会显示fallback属性指定的内容。在这个例子中,当应用还在加载时,会显示一个包含“Loading”的

标签。 @@ -14,6 +15,7 @@ root.render(

} > + {/* 组件用于将Redux store传递给所有的子组件 */} diff --git a/src/reducers/wallpaper.js b/src/reducers/wallpaper.js index 008a62c4c..838ee4360 100644 --- a/src/reducers/wallpaper.js +++ b/src/reducers/wallpaper.js @@ -1,3 +1,4 @@ +// 从localStorage拿到壁纸 var wps = localStorage.getItem("wps") || 0; var locked = localStorage.getItem("locked"); @@ -29,15 +30,19 @@ const defState = { wps: wps, src: walls[wps], locked: !(locked == "false"), + // import.meta.env.MODE == "development" 这段代码是用来检查当前运行环境是否为开发模式 为true booted: false || import.meta.env.MODE == "development", act: "", + // 这个属性应该是用来控制锁屏的吧 dir: 0, }; - +// state 管理的数据初始状态 +// action是个对象,必须有一个type属性,用来表示将要执行的动作 const wallReducer = (state = defState, action) => { switch (action.type) { case "WALLUNLOCK": localStorage.setItem("locked", false); + // 修改之后返回新的state return { ...state, locked: false, @@ -100,6 +105,7 @@ const wallReducer = (state = defState, action) => { wps: wps, src: src, }; + // 如果都不符合 返回原来的state default: return state; }