Linux 程序置顶脚本

引言

当希望我们运行的程序,一直保持在最顶端运行,即置顶状态,那么有很多种方式,这边给出一种脚本方式处理。

通过持续监控,当发现活动窗口不是我们所希望的窗口时,将我们希望置顶的程序窗口置顶。

脚本

bash 复制代码
#!/bin/bash

# 目标窗口的标题
TARGET_WINDOW_TITLE="目标窗口的标题"

# 获取当前活动窗口的ID
ACTIVE_WIN_ID=$(xdotool getactivewindow)

# 使用wmctrl查找目标窗口ID
TARGET_WIN_ID=$(wmctrl -l | grep "$TARGET_WINDOW_TITLE" | awk '{print $1}')

# 检查目标窗口是否已经是活动窗口
if [ "$TARGET_WIN_ID" != "$ACTIVE_WIN_ID" ]; then
    # 如果不是,则置顶目标窗口
    wmctrl -a "$TARGET_WINDOW_TITLE"  
fi

# 设置循环运行,每隔180秒检查一次  
while true; do  
    # 获取当前活动窗口的ID  
    ACTIVE_WIN_ID=$(xdotool getactivewindow)  
  
    # 检查目标窗口是否已经是活动窗口  
    if [ "$TARGET_WIN_ID" != "$ACTIVE_WIN_ID" ]; then  
        # 如果不是,则置顶目标窗口  
        wmctrl -a "$TARGET_WINDOW_TITLE"  
    fi  
  
    # 等待180秒  
    sleep 180  
done

讲解

  1. TARGET_WINDOW_TITLE="目标窗口的标题":这行定义了一个变量 TARGET_WINDOW_TITLE,并将其值设置为"目标窗口的标题"。注意,这里应该替换为实际的窗口标题。

  2. ACTIVE_WIN_ID=$(xdotool getactivewindow):这行使用 xdotool 命令的 getactivewindow 选项来获取当前活动窗口的ID,并将该ID存储在变量 ACTIVE_WIN_ID 中。

  3. TARGET_WIN_ID=$(wmctrl -l | grep "$TARGET_WINDOW_TITLE" | awk '{print $1}'):这行通过管道命令组合 wmctrl -l(列出所有窗口)、grep(搜索包含目标窗口标题的行)和 awk '{print $1}'(打印每行的第一个字段,即窗口ID)来找到目标窗口的ID,并将该ID存储在变量 TARGET_WIN_ID 中。

  4. if [ "$TARGET_WIN_ID" != "$ACTIVE_WIN_ID" ]; then:这行是一个条件判断语句,它检查目标窗口的ID是否不等于当前活动窗口的ID。如果不等,说明目标窗口不是当前活动窗口。

  5. wmctrl -a "$TARGET_WINDOW_TITLE":如果上面的条件为真(即目标窗口不是当前活动窗口),这行命令会使用 wmctrl-a 选项来激活(或置顶)目标窗口。

  6. while true; do:这行开始了一个无限循环,因为 true 总是为真,所以循环会不断执行。

完!

相关推荐
身在江湖的郭大侠2 分钟前
Linux内核
linux·服务器
破-风2 小时前
linux的用法
linux·运维·服务器
涛ing6 小时前
32. C 语言 安全函数( _s 尾缀)
linux·c语言·c++·vscode·算法·安全·vim
__雨夜星辰__6 小时前
Linux 学习笔记__Day2
linux·服务器·笔记·学习·centos 7
大耳朵土土垚6 小时前
【Linux】日志设计模式与实现
linux·运维·设计模式
学问小小谢6 小时前
第26节课:内容安全策略(CSP)—构建安全网页的防御盾
运维·服务器·前端·网络·学习·安全
yaoxin5211237 小时前
第十二章 I 开头的术语
运维·服务器
ProgramHan7 小时前
1992-2025年中国计算机发展状况:服务器、电脑端与移动端的演进
运维·服务器·电脑
马立杰10 小时前
H3CNE-33-BGP
运维·网络·h3cne
云空11 小时前
《DeepSeek 网页/API 性能异常(DeepSeek Web/API Degraded Performance):网络安全日志》
运维·人工智能·web安全·网络安全·开源·网络攻击模型·安全威胁分析