Como funciona
O script abaixo mede o tamanho de uma área, entre dois locais do ponteiro do mouse.
Funciona da seguinte forma:
Coloque o ponteiro do mouse na primeira posição (sem clicar)
Pressione a combinação de teclas de sua escolha (veja mais abaixo)
Coloque o mouse na segunda posição (novamente sem clicar)
Pressione sua combinação de teclas novamente. Uma notificação informará o tamanho exato (px) da área.
Opções
Você pode escolher (removendo o comentário de uma das linhas) como deseja ser notificado; por uma notificação:
Ou uma janela de informações do Zenity:
(Os exemplos são de diferentes áreas)
Como usar
O script usa xdotool
:
sudo apt-get install xdotool
Copie o script abaixo em um arquivo vazio, descomente uma das linhas:
command = ['notify-send', 'Area size', str(w)+' x '+str(h)]
(a ser notificado pela notify-send
opção)
ou:
command = ['zenity', '--info', '--title', 'Area Size', '--text', str(w) + ' x ' + str(h)]
para a Zenity
opção
Salve o script em ~/bin
(você provavelmente precisará criar o diretório) como measure_area
(sem extensão) e torne-o executável .
Adicione uma combinação de teclas de sua escolha para executar o script: Escolha: Configurações do sistema> "Teclado"> "Atalhos"> "Atalhos personalizados". Clique no "+" e adicione o comando:
measure_area
Notas
- Você precisará sair / entrar primeiro
- Não faz diferença o que você toma como primeira / segunda posição; o script mede valores absolutos .
O script
#!/usr/bin/env python3
import subprocess
import os
import math
home = os.environ["HOME"]
area = home+"/"+".measure_area.txt"
def get_pos():
pos_data = subprocess.check_output(["xdotool", "getmouselocation"]).decode("utf-8")
return [m[2:] for m in pos_data.split()[:2]]
def confirm():
get = subprocess.check_output(["xrandr", "--verbose"]).decode("utf-8").split()
for s in [get[i-1] for i in range(len(get)) if get[i] == "connected"]:
br_data = float(get[get.index("Brightness:")+1])
brightness = lambda br: ["xrandr", "--output", s, "--brightness", br]
flash = ["sleep", "0.1"]
for cmd in [brightness(str(br_data-0.1)), flash, brightness(str(br_data))]:
subprocess.call(cmd)
if not os.path.exists(area):
with open(area, "wt") as measure:
measure.write(str(get_pos()))
confirm()
else:
second = get_pos()
with open(area) as first_m:
try:
first = eval(first_m.read())
w = int(math.fabs(int(second[0]) - int(first[0])))
h = int(math.fabs(int(second[1]) - int(first[1])))
#--- uncomment either one of the lines below:
# command = ['notify-send', 'Area size', str(w)+' x '+str(h)]
command = ['zenity', '--info', '--title', 'Area Size', '--text', str(w) + ' x ' + str(h)]
#---
confirm()
except SyntaxError:
text = "Please try again, there was an error in the data"
command = ['zenity', '--info', '--title', 'Please try again', '--text', text]
subprocess.Popen(command)
os.remove(area)
Explicação
Quando o script é chamado pela primeira vez, ele obtém a posição atual do mouse com o xdotool
comando:
xdotool getmouselocation
Em seguida, salva a posição em um arquivo (invisível) .measure_area.txt
, aguardando a segunda chamada.
Na segunda chamada, ele lê o arquivo, remove e compara as x/y
coordenadas armazenadas com as mais recentes e calcula o tamanho da área entre elas.
Editar
Atualizado o script com várias melhorias:
- Otimizado
subprocess.Popen()
/ subprocess.check_output()
comandos (graças a @muru, @Trengot)
- Foi adicionado um procedimento de reparo, caso algo desse errado com o primeiro arquivo de dados (por exemplo, se o usuário tentasse executar o script pela primeira vez sem ter
xdotool
instalado)
- Adicionado um pequeno flash de confirmação na tela de confirmação quando a combinação de teclas é pressionada para as primeiras coordenadas. Parece um pouco mais fácil fornecer ao usuário algum tipo de confirmação da ação.