Amplifier Power On/Off GPIO output

Max2Play Home 2016 (en) Forums Max2Play Development (Ideas, Wishes) Amplifier Power On/Off GPIO output

This topic contains 4 replies, has 4 voices, and was last updated by  Peti premium 7 months, 4 weeks ago.

Viewing 5 posts - 1 through 5 (of 5 total)
  • 25. December 2015 at 23:10 #17482

    Hi I mainly use the Squeezeplug functionality. Could a GPIO pin be set high when audio is playing then set low roughly 30 seconds after audio stops? I could use this to turn on/off my amplifier and save power. I can then install the whole system out of reach.

    I’ve seen the IQAudio amplifier and it looks good, but the PSU is always on and I’m worried about the power consumption when left on 24/7.

    26. December 2015 at 14:50 #17486

    I’ve realised this with fhem (SB_Player / SB_Server) for squeeze – very reliable.

    For shairport and DLNA I’ve did some tests with the CPU-load…. not very successfull…. but squeeze was the most important!

    5. February 2016 at 13:02 #18388

    Im hoping to achieve this too.
    May i ask – Bort – how you realised it with FHEM ?
    Asking for your scripts may be too much !? 🙂

    6. February 2016 at 14:23 #18393

    I’ve found a solution for this !!

    This plugin runs on the Logitech media server and will send TCP commands to specified Squeezeboxes that are currently playing.
    ‘Commands’ can be specified in the LMS settings for the plugin. You then need to create something executable on the players to turn on/off a GPIO pin. I wrote two .c files AmpLatchOn.c and AmpLatchOff.c and compiled them to AmpLatchOn and AmpLatchOff. The ‘commands’ set in the plugin are simply AmpLatchOn and AmpLatchOff

    AmpLatchOn.c :

    #include <wiringPi.h>
    int main (void)
      wiringPiSetup () ;
      pinMode (0, OUTPUT) ;
      digitalWrite (0, HIGH) ; delay (50);
      return 0;

    You may also need to install wiringPi to get this working

    From the bottom of the google code page (linked above), download
    Extract this to a new folder on each player
    Set to run on startup (boot) (I created a bash script to run it and added with crontab I think). This will receive the TCP commands and run the command.
    I had to modify this under ” def handle_command(self, line); ” I altered the command directory to ” Dir = ‘/home/pi/netio/./’ ” as this is where my c-code executables are.

    Takes a bit of setup, but it worked for me!
    It’s exactly the kind of thing that could be made native to M2P/Squeezeplug

    • This reply was modified 1 year, 1 month ago by  Mark One.
    2. August 2016 at 15:15 #21970

    ich hoffe, dass ich nicht nur in englisch schreiben darf… und dass ich das Thema nochmal aufleben lassen kann.
    Die Anleitung von Mark One habe ich ziemlich vollständig abgearbeitet. Ich habe das Plugin im Media-Server installiert. Dann habe ich im Plugin die Werte eingetragen fĂĽr Connection (IP:Port) und Einschaltkommando ( Ich habe Python und WiringPi auch erfolgreich installiert (meine ich) und habe die Dateien aus dem Archiv in einem Unterverzeichnis von /home/pi/netio abgelegt. An der Konsole kann ich mit GPIO -v bzw. GPIO readall sehen, dass mindestens das richtig läuft. Nun wollte ich als Test beim Starten der Musikwiedergabe, dass die Datei ausgefĂĽhrt wird. Die Datei enthält nur einen echo-Befehl. Irgendwie weiĂź ich nun nicht, wo ich noch was konfigurieren muss. Das Schalten der GPIO-Ports wollte ich auch mit einem *.sh Script erledigen. Wie erkenne ich, dass Kommandos gesendet und empfangen werden? Wenn ich sudo python /home/pi/netio/ eingebe, passiert nichts (das sieht aus, als wĂĽrde das Programm in einer Endlos-Schleife hängen)… Ich kann es mit CTRL-C abbrechen und kann erst dann wieder ein neues Kommando eingeben. Vielleicht verstehe ich das auch falsch und das Programm erwartet dann eine Eingabe? Jedenfalls wenn ich die Musikwiedergabe starte sehe ich auch keine Veränderung.
    Ich hoffe, dass mir jemand die nötigen Tipps geben kann.

Viewing 5 posts - 1 through 5 (of 5 total)

You must be logged in to reply to this topic.

Register here