Skip to main content

Provides MainWindow of the kitstarter application.

Project description

qt_liquid_pool

Manages port connections for instances of LiquidSFZ using JackConnectionManager.

Purpose

This library:

  1. Instantiates any number of instances of LiquidSFZ from the "liquiphy" package.

  2. Creates a connection to the JACK audio connection kit and monitors changes in clients and ports for the purpose of managing the ports created by the above-mentioned LiquidSFZ instances.

  3. Optionally fills and updates two instances of QComboBox, which may be used in your project for allowing a user to select input and output devices to connect to the LiquidSFZ instance(s).

Here's a screenshot of the test window, showing two combo boxes for source/sink selection, and a table displaying instantiated synth ports and their connections:

test-window

I found myself using the same blocks of code in several projects, and decided to break these out into a new project which could be generally reused.

Installation

Install from the pypi repository:

$ pip install qt_liquid_pool

Usage:

Import

from qt_liquid_pool import LiquidPool

Extending for custom features

You can write your own class which inherits from LiquidPool in order to provide additional features.

Additional devices

The following class connects and disconnects a soundfile player alongside the built-in instances of LiquidSFZ:

class Audio(LiquidPool):

	def __init__(self):
		super().__init__()
		self.audio_player = None

	def slot_jack_ready(self, state):
		if state:
			self.audio_player = JackAudioPlayer(AUDIO_PLAYER_CLIENT)

	def disconnect_audio_sinks(self, ports):
		super().disconnect_audio_sinks(ports)
		for src, tgt in zip(self.audio_player.output_ports, ports):
			self.conn_man.disconnect(src, tgt)

	def connect_audio_sinks(self, ports):
		super().connect_audio_sinks(ports)
		for src, tgt in zip(self.audio_player.output_ports, ports):
			self.conn_man.connect(src, tgt)

	def play_soundfile(self, soundfile):
		soundfile.seek(0)
		self.audio_player.play_python_soundfile(soundfile)

	def stop_playing(self):
		self.audio_player.stop()

Saved preferred connections

There is no persistent storage mechanism built in which can save and restore your preferred midi input and audio output devices. The following example shows you you can save and restore these values to a QSettings settings object:

class Audio(LiquidPool):

	def __init__(self):
		super().__init__()
		self.settings = QSettings('developer', 'app')

	def get_preferred_midi_source(self):
		return settings.value('MIDISource')

	def set_preferred_midi_source(self, value):
		settings.setValue('MIDISource', value)
		super().set_preferred_midi_source(value)

	def get_preferred_audio_sink(self):
		return settings.value('AudioSink')

	def set_preferred_audio_sink(self, value):
		settings.setValue('AudioSink', value)
		super().set_preferred_audio_sink(value)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

qt_liquid_pool-1.0.1.tar.gz (17.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

qt_liquid_pool-1.0.1-py2.py3-none-any.whl (17.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file qt_liquid_pool-1.0.1.tar.gz.

File metadata

  • Download URL: qt_liquid_pool-1.0.1.tar.gz
  • Upload date:
  • Size: 17.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for qt_liquid_pool-1.0.1.tar.gz
Algorithm Hash digest
SHA256 3b220c8d42dce69a024c6695806d2a5b6b0ac3e10fc2dcdd64254f88b155dd0b
MD5 7d0d51643dc56e48cda0d7ace5c69aaa
BLAKE2b-256 6ca95822700d33ad36ec467b0ac8ebe9eb7976cacdac012665a8799e14bab509

See more details on using hashes here.

File details

Details for the file qt_liquid_pool-1.0.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for qt_liquid_pool-1.0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 bf0d440a8a94959dabf542730cc3b27156bcb495682b615ccf7f4259a0ff5a27
MD5 4701c75fb73bdc44e9f4a1da6e383a9f
BLAKE2b-256 d1e6f4521511a2ef96b035f0c4954289005f3c7688490d8469857e60c3297146

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page