mirror of
https://github.com/kxgx/2.13-Ink-screen-clock.git
synced 2026-05-10 00:44:02 +08:00
Compare commits
55 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
a8059bac56 | ||
|
|
a80e3a2722 | ||
|
|
c60fccb210 | ||
|
|
53e1845ce4 | ||
|
|
3844f71943 | ||
|
|
b2336dcbfb | ||
|
|
5a976157c2 | ||
|
|
b6866ee2b9 | ||
|
|
32565ef2f5 | ||
|
|
0c4282ebc9 | ||
|
|
f8b2c1b332 | ||
|
|
5b5dace7d3 | ||
|
|
04ab97f5b6 | ||
|
|
0565fd6cf5 | ||
|
|
173d7eba78 | ||
|
|
28895e7188 | ||
|
|
8a4ba07f5b | ||
|
|
ecaa4006ce | ||
|
|
c5a3ef0dcf | ||
|
|
99c2bb3152 | ||
|
|
533e76d536 | ||
|
|
26ee5bf6e7 | ||
|
|
a710b293b6 | ||
|
|
3a90a36ffa | ||
|
|
fdd3e6008a | ||
|
|
e3fd070e3c | ||
|
|
5e353f68f6 | ||
|
|
6e0646612b | ||
|
|
d2b4073c98 | ||
|
|
9fb1ef0c6b | ||
|
|
7c39658cdf | ||
|
|
6628fc01e2 | ||
|
|
b505f9a61d | ||
|
|
7db25e5136 | ||
|
|
9e28156c65 | ||
|
|
1be7856992 | ||
|
|
368ed919dd | ||
|
|
7a9108134a | ||
|
|
1aa62fb894 | ||
|
|
d5ff700884 | ||
|
|
c56bd3784e | ||
|
|
597790d4ad | ||
|
|
e8011c7282 | ||
|
|
29de2a7d77 | ||
|
|
b6422c9afa | ||
|
|
9be8d1ac22 | ||
|
|
3d724ac527 | ||
|
|
35facc30f0 | ||
|
|
af205dc591 | ||
|
|
ef387ebf4b | ||
|
|
6ac8e7d4b7 | ||
|
|
a869fc1911 | ||
|
|
a2e657a182 | ||
|
|
a29377cfa7 | ||
|
|
08111ca4fa |
10
README.md
10
README.md
@@ -1,8 +1,9 @@
|
|||||||
# 墨水屏展示当前时间及天气数据
|
# 墨水屏展示当前时间及天气数据
|
||||||
|
|
||||||
首先感谢上游https://github.com/Seek-Huang/2.13-Ink-screen-clock 的代码仓库
|
本项目复刻自[Seek-Huang](https://github.com/Seek-Huang/2.13-Ink-screen-clock)的代码仓库
|
||||||
|
并在此基础上进行改进
|
||||||
|
|
||||||
## 本仓库已添加一键安装部署脚本
|
## 本仓库已添加[一键安装部署脚本](https://github.com/kxgx/2.13-Ink-screen-clock#%E4%BD%BF%E7%94%A8%E8%84%9A%E6%9C%AC%E7%9B%B4%E6%8E%A5%E5%AE%89%E8%A3%85%E6%8E%A8%E8%8D%90)
|
||||||
注意:请先配置完需要的硬件以及系统配置操作再运行脚本
|
注意:请先配置完需要的硬件以及系统配置操作再运行脚本
|
||||||
|
|
||||||
## API说明:
|
## API说明:
|
||||||
@@ -29,7 +30,7 @@
|
|||||||
ps:如果没有使用此模块则需要更改代码内容,以避免运行出错。
|
ps:如果没有使用此模块则需要更改代码内容,以避免运行出错。
|
||||||
以上可能python脚本已解决
|
以上可能python脚本已解决
|
||||||
|
|
||||||
ps:代码里需要nc命令需要安装netcat,安装内容已集成到“需要安装的软件和依赖“https://github.com/kxgx/2.13-Ink-screen-clock#%E9%9C%80%E8%A6%81%E5%AE%89%E8%A3%85%E7%9A%84%E8%BD%AF%E4%BB%B6%E5%92%8C%E4%BE%9D%E8%B5%96
|
ps:代码里需要nc命令需要安装netcat,安装内容已集成到“[需要安装的软件和依赖](https://github.com/kxgx/2.13-Ink-screen-clock#%E9%9C%80%E8%A6%81%E5%AE%89%E8%A3%85%E7%9A%84%E8%BD%AF%E4%BB%B6%E5%92%8C%E4%BE%9D%E8%B5%96)"
|
||||||
|
|
||||||
### 墨水屏2.13inch e-Paper HAT+硬件连接
|
### 墨水屏2.13inch e-Paper HAT+硬件连接
|
||||||
连接树莓派的时候,可以直接将板子插到树莓派的 40PIN 排针上去,注意对好引脚。
|
连接树莓派的时候,可以直接将板子插到树莓派的 40PIN 排针上去,注意对好引脚。
|
||||||
@@ -111,4 +112,5 @@ sudo apt-get update && sudo apt install -y git && sudo apt-get install -y python
|
|||||||
|
|
||||||
特别注意:
|
特别注意:
|
||||||
在代码文件第三十三行,此次代码需要更改,否则将展示默认城市天气数据
|
在代码文件第三十三行,此次代码需要更改,否则将展示默认城市天气数据
|
||||||

|
# 效果展示
|
||||||
|

|
||||||
|
|||||||
29
bin/clean.sh
29
bin/clean.sh
@@ -1,20 +1,27 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
f_name=clean.py
|
f_name="clean.py"
|
||||||
dir=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
dir=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
||||||
logdir=${dir%/*}
|
logdir="${dir}/log"
|
||||||
screen_name="clean_screen"
|
|
||||||
service_name="raspi_e-Paper.service"
|
service_name="raspi_e-Paper.service"
|
||||||
|
hold_time_seconds=3 # 设置维持时间,例如300秒(5分钟)
|
||||||
|
|
||||||
# 停止raspi_e-Paper服务
|
# 停止raspi_e-Paper服务
|
||||||
echo "正在停止$service_name服务..."
|
echo "正在停止$service_name服务..."
|
||||||
sudo systemctl stop $service_name
|
sudo systemctl stop "$service_name"
|
||||||
|
|
||||||
# 查找并结束所有与指定screen_name相关的screen会话
|
# 确保日志目录存在
|
||||||
pids=$(screen -ls | grep $screen_name | awk -F '.' '{print $1}' | awk '{print $1}')
|
mkdir -p "${logdir}"
|
||||||
for pid in $pids; do
|
|
||||||
screen -S $pid -X quit
|
|
||||||
done
|
|
||||||
|
|
||||||
# 创建一个新的screen会话并运行Python脚本
|
# 获取并终止所有与脚本相关的进程
|
||||||
screen -dmS $screen_name /usr/bin/python3 -u $dir/$f_name > $logdir/log/clean-info.log 2>&1
|
pids=$(pgrep -f "$dir/$f_name")
|
||||||
|
if [ -n "$pids" ]; then
|
||||||
|
kill -9 $pids
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 使用nohup在后台运行Python脚本,并将输出重定向到日志文件
|
||||||
|
nohup /usr/bin/python3 -u "$dir/$f_name" > "${logdir}/info-clean.log" 2>&1 &
|
||||||
|
|
||||||
|
# 等待维持时间
|
||||||
|
echo "正在运行脚本,将在 ${hold_time_seconds} 秒后停止服务..."
|
||||||
|
sleep $hold_time_seconds
|
||||||
|
|||||||
@@ -8,7 +8,6 @@ Before=reboot.target
|
|||||||
Type=oneshot
|
Type=oneshot
|
||||||
ExecStart=/bin/bash /root/2.13-Ink-screen-clock/bin/clean.sh
|
ExecStart=/bin/bash /root/2.13-Ink-screen-clock/bin/clean.sh
|
||||||
RemainAfterExit=yes
|
RemainAfterExit=yes
|
||||||
TimeoutSec=5s
|
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=shutdown.target
|
WantedBy=shutdown.target
|
||||||
|
|||||||
@@ -33,25 +33,57 @@ while [ "$#" -gt 0 ]; do
|
|||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
|
|
||||||
|
# 获取当前语言环境变量
|
||||||
|
CURRENT_LANG=$(locale | grep LANG | sed 's/.*=//')
|
||||||
|
|
||||||
|
# 打印当前语言环境变量
|
||||||
|
echo "当前语言环境: $CURRENT_LANG"
|
||||||
|
|
||||||
# 设置语言环境
|
# 设置语言环境
|
||||||
export LANG=$DEFAULT_LANG
|
if [ "$CURRENT_LANG" != "$DEFAULT_LANG" ]; then
|
||||||
export LC_ALL=$DEFAULT_LANG
|
echo "当前语言环境不是 $DEFAULT_LANG,将进行设置"
|
||||||
|
|
||||||
# 如果 locale.gen 中不存在,则添加到 locale.gen
|
# 设置新的语言环境变量
|
||||||
if ! grep -q "^$DEFAULT_LANG UTF-8" /etc/locale.gen; then
|
export LANG=$DEFAULT_LANG
|
||||||
echo "$DEFAULT_LANG UTF-8" | sudo tee -a /etc/locale.gen
|
export LC_ALL=$DEFAULT_LANG
|
||||||
fi
|
|
||||||
|
|
||||||
# 生成 locale
|
# 检查 locale.gen 中是否已存在 DEFAULT_LANG
|
||||||
if ! sudo locale-gen; then
|
found=0
|
||||||
echo "生成 locale 失败" >&2
|
while read -r line; do
|
||||||
exit 1
|
if [[ "$line" == "$DEFAULT_LANG UTF-8" ]]; then
|
||||||
fi
|
found=1
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done < /etc/locale.gen
|
||||||
|
|
||||||
# 重新配置 locales
|
if [ $found -eq 0 ]; then
|
||||||
if ! sudo dpkg-reconfigure --frontend=noninteractive locales; then
|
# 如果不存在,则添加到 locale.gen
|
||||||
echo "重新配置 locales 失败" >&2
|
echo "$DEFAULT_LANG UTF-8" | sudo tee -a /etc/locale.gen
|
||||||
exit 1
|
# 确保 locale.gen 被正确更新
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "无法更新 locale.gen 文件" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "语言环境 $DEFAULT_LANG 已在 locale.gen 中设置,跳过添加"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 生成 locale
|
||||||
|
if ! sudo locale-gen; then
|
||||||
|
# 如果生成失败,打印错误消息并退出
|
||||||
|
echo "生成 locale 失败" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 更新 locale 配置
|
||||||
|
if ! sudo update-locale LANG=$DEFAULT_LANG; then
|
||||||
|
echo "更新 locale 配置失败" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "语言环境设置完成"
|
||||||
|
else
|
||||||
|
echo "当前语言环境已经是 $DEFAULT_LANG,跳过设置"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Debian版本相关命令
|
# Debian版本相关命令
|
||||||
@@ -147,7 +179,7 @@ install_packages() {
|
|||||||
echo "系统更新失败" >&2
|
echo "系统更新失败" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
if ! sudo apt-get install -y git pigpio raspi-config netcat gawk python3-dev python3-pip python3-pil python3-numpy python3-gpiozero python3-pigpio build-essential screen; then
|
if ! sudo apt-get install -y git pigpio raspi-config netcat* gawk python3-dev python3-pip python3-pil python3-numpy python3-gpiozero python3-pigpio build-essential; then
|
||||||
echo "软件包安装失败" >&2
|
echo "软件包安装失败" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
@@ -155,8 +187,9 @@ install_packages() {
|
|||||||
|
|
||||||
# 安装pip包函数
|
# 安装pip包函数
|
||||||
install_pip_packages() {
|
install_pip_packages() {
|
||||||
if ! sudo pip3 install -i "$PIPY_MIRROR" spidev borax pillow requests; then
|
if ! sudo pip3 install -i "$PIPY_MIRROR" spidev borax pillow requests --break-system-packages; then
|
||||||
echo "pip软件包安装包失败" >&2
|
echo "pip软件包安装包失败" >&2
|
||||||
|
exit 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -209,7 +242,7 @@ setup_service() {
|
|||||||
# 主逻辑
|
# 主逻辑
|
||||||
# 检测是否是Debian系统
|
# 检测是否是Debian系统
|
||||||
if [ -f /etc/debian_version ]; then
|
if [ -f /etc/debian_version ]; then
|
||||||
echo "检测到Debian系统"
|
echo "检测到Debian$DEBIAN_VERSION系统"
|
||||||
|
|
||||||
# 提取版本号的小数点前的部分
|
# 提取版本号的小数点前的部分
|
||||||
if ! MAJOR_VERSION=$(echo $DEBIAN_VERSION | cut -d '.' -f 1); then
|
if ! MAJOR_VERSION=$(echo $DEBIAN_VERSION | cut -d '.' -f 1); then
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ def Local_strong_brush(): #局部强制刷新显示
|
|||||||
i = i + 1
|
i = i + 1
|
||||||
def getWeath(city='101060111'): #天气函数,下载json天气至本地
|
def getWeath(city='101060111'): #天气函数,下载json天气至本地
|
||||||
headers = {
|
headers = {
|
||||||
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/94.0.4606.81 Safari/537.36 Edg/94.0.992.50',
|
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36',
|
||||||
'Referer':'http://www.weather.com.cn/'
|
'Referer':'http://www.weather.com.cn/'
|
||||||
}
|
}
|
||||||
response = requests.get('http://d1.weather.com.cn/sk_2d/'+city+'.html',headers=headers)
|
response = requests.get('http://d1.weather.com.cn/sk_2d/'+city+'.html',headers=headers)
|
||||||
@@ -141,10 +141,6 @@ def Weather(): #在图片中添加天气内容
|
|||||||
|
|
||||||
def Basic_refresh(): #全刷函数
|
def Basic_refresh(): #全刷函数
|
||||||
logging.info("Refresh and prepare the basic content before starting the canvas")#开始画布前刷新准备基础内容
|
logging.info("Refresh and prepare the basic content before starting the canvas")#开始画布前刷新准备基础内容
|
||||||
epd.init()
|
|
||||||
epd.Clear(0xFF)
|
|
||||||
epd.init()
|
|
||||||
epd.Clear(0xFF)
|
|
||||||
global get_date_var
|
global get_date_var
|
||||||
get_date_var=get_date() #记录开始数据
|
get_date_var=get_date() #记录开始数据
|
||||||
draw.text((2,2),get_date_var,font = font02,fill =0)#将日期及星期几显示到屏幕
|
draw.text((2,2),get_date_var,font = font02,fill =0)#将日期及星期几显示到屏幕
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
[Unit]
|
[Unit]
|
||||||
Description=Raspi e-Paper Service
|
Description=Raspi e-Paper Service
|
||||||
After=network-online.target
|
After=network.target
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
Type=forking
|
Type=forking
|
||||||
# 等待网络完全启动
|
# 等待网络完全启动
|
||||||
#ExecStartPre=systemd-networkd-wait-online --timeout=30
|
ExecStartPre=/bin/bash -c 'until ping -c1 baidu.com &>/dev/null; do sleep 1; done'
|
||||||
ExecStart=/root/2.13-Ink-screen-clock/bin/start.sh
|
ExecStart=/root/2.13-Ink-screen-clock/bin/start.sh
|
||||||
ExecStop=/usr/bin/screen -S main_screen -X quit
|
ExecStop=/usr/bin/screen -S main_screen -X quit
|
||||||
Restart=on-failure
|
Restart=on-failure
|
||||||
|
|||||||
15
bin/start.sh
15
bin/start.sh
@@ -1,15 +1,10 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
f_name=main.py
|
f_name=main.py
|
||||||
dir=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
dir=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
||||||
logdir=${dir%/*}
|
logdir=${dir%/*}
|
||||||
screen_name="main_screen"
|
pid=`ps -ef |grep $dir/$f_name | grep -v grep |awk '{print $2}'`
|
||||||
|
for id in $pid
|
||||||
# 查找并结束所有与指定screen_name相关的screen会话
|
do
|
||||||
pids=$(screen -ls | grep $screen_name | awk -F '.' '{print $1}' | awk '{print $1}')
|
kill -9 $id
|
||||||
for pid in $pids; do
|
|
||||||
screen -S $pid -X quit
|
|
||||||
done
|
done
|
||||||
|
nohup /usr/bin/python3 -u $dir/$f_name > $logdir/log/info.log 2>&1 &
|
||||||
# 创建一个新的screen会话并运行Python脚本
|
|
||||||
screen -dmS $screen_name /usr/bin/python3 -u $dir/$f_name > $logdir/log/info.log 2>&1
|
|
||||||
|
|||||||
BIN
pic/1736672578025.jpg
Normal file
BIN
pic/1736672578025.jpg
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 7.0 MiB |
Reference in New Issue
Block a user