桌面时钟(JS版本)-electron

发布于:2022-12-17 ⋅ 阅读:(604) ⋅ 点赞:(0)

无聊的时候随手写的,实现桌面的时钟,别问我为哈不直接看电脑屏幕时间,因为好看啊

适用于Mac以及win

 下面直接上代码

(结构目录)

clock.html:时钟界面绘制

clock.css:css部分

index.html:引入

main.js:配置文件

package.json:依赖

favicon.ico:桌面图标

第一部分:用jQuery以及基础js语法绘制环形页面

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>jquery环形进度条</title>
		<script src="./assets/js/jquery-3.2.1.js"></script>
		<link href="./assets/css/clock.css" rel="stylesheet" type="text/css" />
	</head>
	<body>
		<div class="circle-wraps" >
			<div class="circle-wrap">
				<div class="circle">
					<div class="pie-left">
						<div class="left"></div>
					</div>
					<div class="pie-right">
						<div class="right"></div>
					</div>
					<div class="mask"><span></span></div>
				</div>
			</div>
			<div class="circle-wrap_m">
				<div class="circle">
					<div class="pie-left">
						<div class="left"></div>
					</div>
					<div class="pie-right">
						<div class="right"></div>
					</div>
				</div>
			</div>

			<div class="circle-wrap_h">
				<div class="circle">
					<div class="pie-left">
						<div class="left"></div>
					</div>
					<div class="pie-right">
						<div class="right"></div>
					</div>
				</div>
			</div>

			<div class="circle-wrap_y">
				<div class="circle">
					<div class="pie-left">
						<div class="left"></div>
					</div>
					<div class="pie-right">
						<div class="right"></div>
					</div>
				</div>
			</div>

		</div>

		<script>
			$(function() {
				var leftContent_s = document.querySelector(".circle-wrap .left");
				var rightContent_s = document.querySelector(".circle-wrap .right");
				var leftContent_m = document.querySelector(".circle-wrap_m .left");
				var rightContent_m = document.querySelector(".circle-wrap_m .right");
				var leftContent_h = document.querySelector(".circle-wrap_h .left");
				var rightContent_h = document.querySelector(".circle-wrap_h .right");
				var leftContent_y = document.querySelector(".circle-wrap_y .left");
				var rightContent_y = document.querySelector(".circle-wrap_y .right");
				var textCircle = document.querySelector(".mask");
				var monthArr = ['', 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'June', 'July', 'Aug', 'Sept', 'Oct', 'Nov',
					'Dec'
				]
				var weekArr = ['', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday']
				//先是leftContent旋转角度从0增加到180度,
				//然后是rightContent旋转角度从0增加到180度
				var angle_s = 0;
				var angle_m = 0;
				var angle_h = 0;
				var angle_y = 0;

				var timerId = setInterval(function() {
					var myDate = new Date();
					var month = myDate.getMonth() + 1; //获取当前月
					var week = myDate.getDay();
					var date = myDate.getDate(); //获取当前日
					
					var s = myDate.getSeconds();

					angle_y = parseInt(month) * 30;
					angle_h = parseInt(myDate.getHours()) * 15; //获取当前小时数(0-23)
					angle_m = parseInt(myDate.getMinutes()) * 6; //获取当前分钟数(0-59)
					angle_s = parseInt(getNow(s)) * 6;
					var noon = 'AM';
					if(myDate.getHours()>12){
						noon = 'PM';
					}else{
						noon = 'AM';
					}
					now = weekArr[week] + '<br>' + monthArr[month] + ' ' + date + '<br><p style="margin:0;margin-top:10px;font-size:20px;line-height:24px">' + getNow(myDate.getHours()) +':'+ getNow(myDate.getMinutes()) +':'+ getNow(s)+'</p><br>'+noon;
					if (angle_s > 360) {
						clearInterval(timerId);
					} else {
						console.log(myDate.getHours());
						if (angle_s == 0) {
							angle_s = 360;
						}
						if (angle_s > 180) {
							leftContent_s.setAttribute('style', 'transform: rotate(' + (angle_s) + 'deg)');
						} else {
							rightContent_s.setAttribute('style', 'transform: rotate(' + (angle_s + 180) +
								'deg)');
							leftContent_s.setAttribute('style', 'transform: rotate(180deg)');
						}

						if (angle_m == 0) {
							angle_m = 360;
						}
						if (angle_m > 180) {
							leftContent_m.setAttribute('style', 'transform: rotate(' + (angle_m) + 'deg)');

						} else {
							rightContent_m.setAttribute('style', 'transform: rotate(' + (angle_m + 180) +
								'deg)');
							leftContent_m.setAttribute('style', 'transform: rotate(180deg)');
						}

						if (angle_h == 0) {
							angle_h = 360;
						}
						if (angle_h > 180) {
							leftContent_h.setAttribute('style', 'transform: rotate(' + (angle_h) + 'deg)');

						} else {
							rightContent_h.setAttribute('style', 'transform: rotate(' + (angle_h + 180) +
								'deg)');
							leftContent_h.setAttribute('style', 'transform: rotate(180deg)');
						}

						if (angle_y == 0) {
							angle_y = 360;
						}
						if (angle_y > 180) {
							leftContent_y.setAttribute('style', 'transform: rotate(' + (angle_y) + 'deg)');

						} else {
							rightContent_y.setAttribute('style', 'transform: rotate(' + (angle_y + 180) +
								'deg)');
							leftContent_y.setAttribute('style', 'transform: rotate(180deg)');
						}
						setPercent(now);
					}
				}, 1000);

				function setPercent(text) {
					textCircle.innerHTML = text;
				}

				function getNow(s) {
					return s < 10 ? '0' + s : s;
				}
			});
		</script>
	</body>
</html>
body {
 	background: transparent;
 }

 .platelet {
 	-webkit-app-region: drag;
 	position: fixed;
 	bottom: 0;
 	left: 10;
 	z-index: 1;
 	font-size: 0;
 	transition: all 0.3s ease-in-out;
 	-webkit-transform: translateY(3px);
 	transform: translateY(3px);
 }

 .platelet:hover {
 	-webkit-transform: translateY(0);
 	transform: translateY(0);
 }

 @media (max-width: 768px) {
 	.platelet {
 		display: none;
 	}
 }

 .circle {
 	width: 180px;
 	height: 180px;
 	position: absolute;
 	border-radius: 50%;
 	border: 10px solid rgba(39, 19, 54, 0.8);
 }

 .pie-left,
 .pie-right {
 	width: 200px;
 	height: 200px;
 	position: absolute;
 	left: -10px;
 	right: -10px;
 	top: -10px;
 }

 .left,
 .right {
 	display: block;
 	width: 180px;
 	height: 180px;
 	border-radius: 50%;
 	border: 10px solid rgba(168, 0, 241, 1);
 	position: absolute;
 	left: 0px;
 	top: 0px;
 }

 .pie-right,
 .right {
 	clip: rect(0, auto, auto, 100px);
 }

 .pie-left,
 .left {
 	clip: rect(0, 100px, auto, 0);
 }

 .mask {
 	width: 200px;
 	height: 200px;
 	border-radius: 50%;
 	position: absolute;
 	left: -10px;
 	top: -10px;
 	background: transparent;
 	display: flex;
 	align-items: center;
 	justify-content: center;
 	text-align: center;
 	font-size: 8px;
 	color: rgba(255, 255, 255, 0.8);
 	line-height: 10px;
 	font-family: 'BlinkMacSystemFont', "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
 	flex-direction: column;
 }

 .circle-wraps {
 	width: 200px;
 	height: 200px;
 	position: relative;
 	margin: 0 auto;
 	display: flex;
 	align-items: center;
 	justify-content: center;
 }

 .circle-wrap_m {
 	width: 155px;
 	height: 155px;
 	position: absolute;
 	top: 11.5px;
 	left: 11.5px;
 }

 .circle-wrap_m .circle {
 	width: 155px;
 	height: 155px;
 	position: absolute;
 	border-radius: 50%;
 	border: 10px solid rgba(20, 35, 54, 0.8);
 }

 .circle-wrap_m .pie-left,
 .circle-wrap_m .pie-right {
 	width: 175px;
 	height: 175px;
 	left: -10px;
 	right: -10px;
 	top: -10px;
 }

 .circle-wrap_m .left,
 .circle-wrap_m .right {
 	display: block;
 	width: 155px;
 	height: 155px;
 	border-radius: 50%;
 	border: 10px solid rgba(30, 90, 240, 1);
 	position: absolute;
 	left: 0px;
 	top: 0px;
 }

 .circle-wrap_m .pie-right,
 .circle-wrap_m .right {
 	clip: rect(0, auto, auto, 87.5px);
 }

 .circle-wrap_m .pie-left,
 .circle-wrap_m .left {
 	clip: rect(0, 87.5px, auto, 0);
 }

 .circle-wrap {
 	width: 200px;
 	height: 200px;
 	position: absolute;
 }

 .circle-wrap_h {
 	width: 115px;
 	height: 115px;
 	position: absolute;
 	top: 25px;
 	left: 25px;
 }

 .circle-wrap_h .circle {
 	width: 130px;
 	height: 130px;
 	position: absolute;
 	border-radius: 50%;
 	border: 10px solid rgba(52, 36, 23, 0.8);
 }

 .circle-wrap_h .pie-left,
 .circle-wrap_h .pie-right {
 	width: 150px;
 	height: 150px;
 	left: -10px;
 	right: -10px;
 	top: -10px;
 }

 .circle-wrap_h .left,
 .circle-wrap_h .right {
 	display: block;
 	width: 130px;
 	height: 130px;
 	border-radius: 50%;
 	border: 10px solid rgba(239, 172, 29, 1);
 	position: absolute;
 	left: 0px;
 	top: 0px;
 }

 .circle-wrap_h .pie-right,
 .circle-wrap_h .right {
 	clip: rect(0, auto, auto, 75px);
 }

 .circle-wrap_h .pie-left,
 .circle-wrap_h .left {
 	clip: rect(0, 75px, auto, 0);
 }

 .circle-wrap_y {
 	width: 100px;
 	height: 100px;
 	position: absolute;
 	top: 38px;
 	left: 38px;
 }

 .circle-wrap_y .circle {
 	width: 105px;
 	height: 105px;
 	position: absolute;
 	border-radius: 50%;
 	border: 10px solid rgba(52, 20, 40, 0.8);
 }

 .circle-wrap_y .pie-left,
 .circle-wrap_y .pie-right {
 	width: 125px;
 	height: 125px;
 	left: -10px;
 	right: -10px;
 	top: -10px;
 }

 .circle-wrap_y .left,
 .circle-wrap_y .right {
 	display: block;
 	width: 105px;
 	height: 105px;
 	border-radius: 50%;
 	border: 10px solid rgba(238, 0, 77, 1);
 	position: absolute;
 	left: 0px;
 	top: 0px;
 }

 .circle-wrap_y .pie-right,
 .circle-wrap_y .right {
 	clip: rect(0, auto, auto, 62.5px);
 }

 .circle-wrap_y .pie-left,
 .circle-wrap_y .left {
 	clip: rect(0, 62.5px, auto, 0);
 }

第二部分:index.html引入时钟模块 

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<meta name="viewport" content="width=device-width,initial-scale=1">
		<meta http-equiv="X-UA-Compatible" content="ie=edge">
		<link href="./assets/css/clock.css" rel="stylesheet" type="text/css">
		<script>
			delete module.exports;
		</script>
	</head>
	<body>
		<div class="platelet" style="display:block">
			<div style="width:250px;overflow:hidden" class="wid"><iframe frameborder="0" scrolling="no" src="clock.html"
					style="width:300px;height:300px;cursor:pointer" id="canvas"></iframe></div>
		</div>
		<div id="main" class="container"></div>
	</body>
	<script src="./assets/js/jquery-3.2.1.js"></script>
</html>

第三部分:系统配置

const path = require("path");
const {
	app,
	BrowserWindow,
	TouchBar,
	ipcMain,
	screen
} = require("electron");
const {
	TouchBarButton
} = TouchBar;
const MAIN_WIDTH = 320;
const MAIN_HEIGHT = 350;
const spin = new TouchBarButton({
	label: "时钟",
	backgroundColor: "#7851A9",
	click: () => {
		console.log("时钟")
	}
});
let spins = [spin];
const touchBar = new TouchBar({
	items: spins
});
let mainWindow, settingWindow;

function createWindow() {
	const display = screen.getPrimaryDisplay();
	const {
		width,
		height
	} = display.bounds;
	mainWindow = new BrowserWindow({
		width: MAIN_WIDTH,
		height: MAIN_HEIGHT,
		title: "桌面时钟",
		hasShadow: false,
		transparent: true,
		resizable: false,
		frame: false,
		focusable: true,
		alwaysOnTop: true,
		maximizable: false,
		show: false,
		x: width - MAIN_WIDTH,
		y: height - MAIN_HEIGHT,
		webPreferences: {
			devTools: true,
			nodeIntegration: true,
			nodeIntegrationInWorker: true
		}
	});
	mainWindow.on("closed", () => (mainWindow = null));
	mainWindow.loadFile(path.join(__dirname, "index.html"));
	mainWindow.once("ready-to-show", () => {
		mainWindow.show();
		mainWindow.setTouchBar(touchBar)
	})
}
app.on("ready", () => createWindow());
app.on("window-all-closed", () => {
	if (process.platform !== "darwin") {
		app.quit()
	}
});
if (process.platform === "darwin") {
	app.setAboutPanelOptions({
		applicationName: "deskDopClock",
		applicationVersion: app.getVersion(),
		copyright: "2022-4-11",
		credits: "Sun"
	})
}
app.on("activate", () => {
	if (mainWindow === null) {
		createWindow()
	}
});
app.on("second-instance", () => {
	if (mainWindow) {
		if (mainWindow.isMinimized()) mainWindow.restore();
		mainWindow.focus()
	}
});
ipcMain.on("show-setting-window", () => {
	createSettingWindow()
});
ipcMain.on("hide-setting-window", event => {
	settingWindow.hide()
});

第三部分:所含依赖以及打包配置(我就是小太阳,哈哈哈)

{
  "name": "clock",
  "version": "2.0.0",
  "description": "桌面时钟-by_-littleSun",
  "main": "main.js",
  "scripts": {
    "start": "electron .",
    "package": "electron-packager . DeskClock --platform=mas --out=./out --election-version=0.0.1 --overwrite --icon=./favicon.ico",
    "package:win": "electron-packager . DeskClock --platform=win32 --arch=x64 --out=./outWin --election-version=0.0.1 --ignore=node_modules --overwrite --icon=./favicon.ico"
  },
  "keywords": [
    "deskDop",
    "CLOCK"
  ],
  "author": "littleSun",
  "license": "CC0-1.0",
  "devDependencies": {
    "electron": "9.4.4"
  },
  "dependencies": {
    "dark-mode": "^3.0.0",
    "electron-store": "^5.1.1"
  }
}

 放在黑色背景里还阔以吧!

后来我又进行优化,用svg语法重写了这个组件

增加了弧度和渐变色 以及流畅度,资源 看情况下载,或者自己根据JS版本进行

桌面应用程序-时钟svg-Javascript文档类资源-CSDN下载