Як було сказано в коментарі, я не міг змусити згадані метрономи (існуючі для Linux / Ubuntu) працювати 16.04, принаймні, не з коробки. Я не витрачав багато часу на те, щоб змусити його працювати , оскільки практично всі вони створюють враження, що їх покинули.
Час написати одне ...
Ця відповідь ( незавершена робота ) повинна врешті-решт призвести до метроному, включаючи GUI. Вдалий час згадати можливі функції, які ви хочете.
1. Метроном CLI
Створення прямого метронома виявляється приголомшливо простим:
#!/usr/bin/env python3
import subprocess
import sys
import time
bpm = int(sys.argv[1])
pauze = 60/bpm
while True:
time.sleep(pauze)
subprocess.Popen(["ogg123", "/usr/share/sounds/ubuntu/stereo/bell.ogg"])
Як користуватись
Метроному потрібні інструменти vorbis для відтворення звуку
sudo apt-get install vorbis-tools
- Скопіюйте сценарій вище в порожній файл, збережіть його як metronome.py
Запустіть його аргументом bpm як аргумент:
python3 /path/to/metronome.py <bpm>
наприклад:
python3 /path/to/metronome.py 100
Запускати його зі 100 ударами в хвилину
Примітка
Для звуку я використав файл /usr/share/sounds/ubuntu/stereo/bell.ogg
, який за замовчуванням повинен бути у вашій системі (перевірено 14.04 / 16.04). Однак ви можете використовувати будь-який ( .ogg
) зразок, який вам подобається. В остаточній версії буде доступна низка варіантів (звуків).
2. Шокуюче проста версія GUI
Наступним кроком є дуже основна версія, остання версія без інсталятора:
Сценарій
#!/usr/bin/env python3
import gi
gi.require_version('Gtk', '3.0')
from gi.repository import Gtk
import sys
import subprocess
import time
from threading import Thread
import os
path = os.path.dirname(os.path.realpath(__file__))
class MetroWindow(Gtk.Window):
def __init__(self):
Gtk.Window.__init__(self, title="Shockingly simple Metronome")
self.speed = 70
self.run = False
# maingrid
maingrid = Gtk.Grid()
maingrid.set_column_homogeneous(True)
maingrid.set_row_homogeneous(False)
maingrid.set_border_width(30)
self.add(maingrid)
# icon
image = Gtk.Image(xalign=0)
image.set_from_file(os.path.join(path, "icon.png"))
maingrid.attach(image, 0, 0, 1, 1)
# vertical slider, initial value, min, max, step, page, psize
self.v_scale = Gtk.Scale(
orientation=Gtk.Orientation.VERTICAL,
adjustment=Gtk.Adjustment.new(self.speed, 10, 240, 1, 0, 0)
)
self.v_scale.set_vexpand(True)
self.v_scale.set_digits(0)
self.v_scale.connect("value-changed", self.scale_moved)
maingrid.attach(self.v_scale, 1, 0, 2, 1)
self.togglebutton = Gtk.Button("_Run", use_underline=True)
self.togglebutton.connect("clicked", self.time_out)
self.togglebutton.set_size_request(70,20)
maingrid.attach(self.togglebutton, 3, 3, 1, 1)
# start the thread
self.update = Thread(target=self.run_metro, args=[])
self.update.setDaemon(True)
self.update.start()
def scale_moved(self, event):
self.speed = int(self.v_scale.get_value())
def time_out(self, *args):
if self.run == True:
self.run = False
self.togglebutton.set_label("Run")
else:
self.run = True
self.togglebutton.set_label("Pauze")
def pauze(self):
return 60/self.speed
def run_metro(self):
soundfile = "/usr/share/sounds/ubuntu/stereo/bell.ogg"
while True:
if self.run == True:
subprocess.Popen([
"ogg123", soundfile
])
time.sleep(self.pauze())
def run_gui():
window = MetroWindow()
window.connect("delete-event", Gtk.main_quit)
window.set_resizable(False)
window.show_all()
Gtk.main()
run_gui()
Зображення
Як користуватись
Як і версія cli, і цій потрібна vorbis-tools
:
sudo apt-get install vorbis-tools
Скопіюйте скрипт у порожній файл, збережіть його як metro.py
- Клацніть правою кнопкою миші на зображення вище, зберегти його в одному і тому ж каталозі, що і скрипт (точно) , як:
icon.png
.
Просто запустіть метроном командою:
python3 /path/to/metro.py
3. PPA для помаранчевого метронома
Це робиться!
Метроном готовий до встановлення.
Помаранчевий Метроном поставляється з набором різних звуків на вибір, і удари можна групувати. Всі зміни застосовуються негайно до запущеного метроному:
Щоб встановити:
sudo apt-add-repository ppa:vlijm/orangemetronome
sudo apt-get update
sudo apt-get install orangemetronome
Роботу робити
В даний час метроном оснащений чотирма різними звуками на вибір. Ймовірно, кілька буде додано в найближчі кілька днів, деякі з них будуть замінені / оновлені
На більш
тривалий термін Я думаю про те, щоб додати варіант для (замовних) складних структур, таких як 3 + 3 + 2, 2 + 2 + 2 + 3 і т.д., які я завжди пропускав у існуючих метрономах.
Нарешті
Остання (поточна) версія 0.5.3
додає низку звуків, але що ще важливіше, можливість запускати нерегулярні (складені) удари. У цій версії вони жорстко закодовані. Буде налаштовано з версії> 1.