我使用简单的脚本来制作 CPU 使用情况的动态状态栏(见下文)。启动 fvwm 后它可以工作,但 3-4 分钟后该条消失了! cpu.sh 很简单(见下文)。如果没有 ChangeSize,就不会崩溃(但没有动态栏,只有静态栏)。 cpu.sh 给出整数,因为 ChangeSize 需要整数。这次崩溃的原因可能是什么?我已经花了两天了,不明白原因。
WindowTitle {Status}
WindowSize 120 30
##### Global Style
Font "xft:DejaVu Sans:size=8:bold"
Init
Begin
Set $probarColor = {#cccccc}
##### Widgets
ChangeBackColor 1 $probarColor
ChangeBackColor 3 $probarColor
End
PeriodicTasks
Begin
##### CPU Status
If (RemainderOfDiv (GetTime) 2) == 0 Then
Begin
Set $length = (GetOutput {echo $(bash $HOME/.fvwm/scripts/StaTux/cpu.sh)} 1 -1)
ChangeSize 3 $length 3
End
End
Widget 1
Property
Type ItemDraw
Size 120 4
Position 0 0
Flags NoFocus NoReliefString
Main
Case message of
End
Widget 2
Property
Type ItemDraw
Size 118 2
Position 1 1
Flags NoFocus NoReliefString
Main
Case message of
End
Widget 3
Property
Type ItemDraw
Size 118 2
Position 1 1
Flags NoFocus NoReliefString
Main
Case message of
End
cpu.sh
#!/bin/sh
DELAY=${1:-1}
{ cat /proc/stat; sleep "$DELAY"; cat /proc/stat; } | awk '/^cpu / {usr=$2-usr; sys=$4-sys; idle=$5-idle; iow=$6-iow} END {total=usr+sys+idle+iow; print int((total-idle)*118/total)}'
答案1
正如评论中所讨论的,似乎FvwmScript
由于 X 错误而崩溃坏值当 shell 脚本返回的值为 0 时。这可能是因为它试图将窗口大小配置为 0。
另一种解决方案是使用HDipstick
小部件,它是固定长度框中的水平条。这是一个简短但完整的示例:
WindowTitle {Status}
WindowSize 120 30
WindowPosition 900 1
Init
Begin
ChangeBackColor 3 {#000}
End
PeriodicTasks
Begin
If (RemainderOfDiv (GetTime) 2) == 0 Then
Begin
Set $length = (GetOutput {bash $HOME/.fvwm/scripts/StaTux/cpu.sh} 1 -1)
ChangeValue 3 $length
End
End
Widget 3
Property
Type HDipstick
Value 0
MinValue 0
MaxValue 200
ForeColor {#f00}
Size 110 20
Position 5 5
Main
Case message of
End
并设置从脚本返回的预期数量限制MinValue
。MaxValue
我随意选了200。PeriodicTasks
脚本的调用获取此数字并用于为其设置属性ChangeValue
。Value
它将通过除以 200 并乘以水平条的宽度(此处以Size
110 像素为单位)进行缩放。
在使用这个时,我注意到我的 FvwmScript 版本中存在一个错误,它会为某些低值绘制完整的条形。例如,将 a 设置MaxValue
为 700 意味着值 7 到 26 给出完整的条形。