![]() |
Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Hallo!
Also ich such jetzt schon zwei Tage aber finden kann ich zu diesem Problem nichts: Wie kann man in einer Multi-Monitor-Umgebung einen bestimmten Monitor (eben NICHT alle zusammen) in den Standby schicken. Lösungen wie diese:
Delphi-Quellcode:
findet man zu Hauf im Netz, aber das schickt bestenfalls nur alle Monitore gemeinsam in den Standby, nicht einen bestimmten.
SendMessage(HWND_BROADCAST, WM_SYSCOMMAND, SC_MONITORPOWER, 2);
Möglicherweise kann das Windows auch von der Logik her nicht, da jede Mausbewegung oder Tastendruck eigentlich die Bildschirme wieder aufweckt. Dann wäre es schlicht unmöglich, einen von mehreren Bildschirmen in den Standby zu schicken und an dem/den anderen weiter zu arbeiten. Vielleicht gehts aber doch und einer von euch hat eine Idee? Grüße Cody |
AW: Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Da ich ähnliches denke, was du schon befürchtest, würde ich eher danach gucken, wie man einen Bildschirm aus der Konfiguration entfernen kann. Quasi so, als würde man in der Systemsteuerung "Diesen Monitor verwenden" abschalten. Ggf. gibt es da einen Weg via WMI o.ä.
Nur Standby hätte auch den unschönen Nebeneffekt, dass der Moni dann ja logisch noch vorhanden wäre, sich Windows also nicht wie mit nur einem verhält. Das führt gerne mal zu "verlorenen" Fenstern und Desktop-Icons die man nicht mehr findet. |
AW: Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Das logische Entfernen bzw. logische Deaktivieren kann aber auch unschöne Seiteneffekte haben. Dann werden evtl. auf dem Desktop platzierte Icons verschoben oder diverse Window Geometrics "sabotiert". Hat schon mal jemand gesehen was die Delphi-7-IDE unter Windows 7 für eine Show veranstaltet, wenn man die Auflösung ändert? Das sieht dann aus als würde sie im Schneckentempo Amok laufen.
Ich denke ich werde das erstmal bleiben lassen mit dem gezielten Abschalten einzelner Monitore. Braucht man einen Blackscreen kann man zur Not ein rahmenloses schwarzes Fenster StayOnTop da hinstellen. Der Gedanke dahinter war eine Rechner-Bildschirm-Beamer-Konfiguration, wobei der Beamer nicht wie üblich den Desktop spiegelt sondern Teil des Desktops ist. Das Bild über den Beamer wird dann erst "hell" wenn der Anwender es will. So er vorher noch etwas auf dem Rechner zu tun hat das nicht alle über den Beamer sehen sollen. Das kann dann von Nutzen sein wenn der Beamer nicht gleich neben dem Rechner steht und man auch keine Fernbedienung hat (z.B. bei Präsentationen an fremden Beamern). |
AW: Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Soweit ich weiß, gibt es bei einigen Beamern eine serielle Schnittstele, wo man den Beamer steuern kann. Vielleicht kann man über diese Schnittstelle, falls vorhanden, den Beamer mal auf Standby schalten.
Lg, jus |
AW: Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Zitat:
Damit kann man erstmal sein zeug machen (über den beamer sieht man dann nur den Desktophintergrund) und wenn man loslegen möchte das Fenster nach rechts verschieben und loslegen. Powerpoint erkennt den Beamer vll. sogar selbst so dass die Präsentation direkt dort startet. |
AW: Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Windows kann diese Aufgabenstellung nicht vernünftig lösen.
Ich würde in dieser Situation mit einer schaltbaren Stromschiene (bspw. per RS232) die Stromversorgung des Monitors ein-/ausschalten. |
AW: Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Ich denke auch, dass das der Weg ist.
Einfach mal schauen ob der Beamer eine serielle Schnittstelle hat und ob man das Protokoll in die Finger bekommt. Neuere Modelle, die keine Serielle Schnittstelle mehr haben lassen sich oftmals auch per LAN (soweit vorhanden) bedienen. Auch hier braucht man Zugriff auf das Protokoll wenn man nicht zu viel reverse engeneering betreiben will. Nachteil diese Lösung ist ganz klar, dass ein anderer beamer andere Schnittstellen hat und ein anderes Protokoll fährt. Ein wenig flexibler wäre man mit einer WinLIRC-Lösung. Hier bräuchte dann nur jeweils der Fernbedienungscode für Ein/Aus angelernt werden. Code gibts zu Hauf im Netz. Toni |
AW: Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Win-P ist nichts was man programmatisch nutzen könnte, außerdem hat es die selben negativen Seiteneffekte wie schon beschrieben (Icon-Schubserei)
Das mit der seriellen Schnittstelle ist nicht unbedingt das Mittel der Wahl da das immer proprietär ist. Na vielleicht fällt mir ja noch was Gescheites ein :-) |
AW: Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Liste der Anhänge anzeigen (Anzahl: 2)
Ahoi,
mittels ![]() hth ACHTUNG: Der Code kann die Monintoreinstellungen zu unbrauchbaren Werten hin ändern. Prüfe ggf. vorher ob du deinen Monitor über das OSD zurücksetzen kannst. Zum Factory Reset über den Source verwende die im "VESA Monitor Control Command Set" (Tabelle 8.1) definierten Codes. Shalom EDIT: Units hinzugefügt (TPmMoniControl ist als Singleton implementiert, deswegen hab ich auch die Singleton unit angefügt [die es hier auch im Forum geben müsste]). Das Ganze war wie gesagt ein Testproject und erhebt kein Anspruch auf Vollständigkeit ABER man konnte einzelne Monitor abschalten. Verwendungsbeispiel: die Methode "actToggleMoniPower" wird einer Action zugewiesen. Im "Tag"-Property der Action muss die Monitornummer stehen. Auf dem Form sind eine TListBox, eine TTreeView und um Codes zu senden eine TEdit und ein Button.
Delphi-Quellcode:
function EnumDisplayMonitorsCallback(hm: HMONITOR; dc: HDC; r: PRect; l: LPARAM): Boolean; stdcall;
//Callback für Auflistung aller Monitore function RectToStr: String; begin Result := Format('%d-%d %d|%d', [r.Left, r.Right, r.Top, r.Bottom]); end; begin Form1.lbMonitorsAvailabe.AddItem(RectToStr, TObject(hm)); end; procedure TForm1.FormCreate(Sender: TObject); begin EnumDisplayMonitors(0, nil, EnumDisplayMonitorsCallback, 0); end; procedure TForm1.lbMonitorsAvailabeClick(Sender: TObject); begin //Vom Monitor unterstützte Codes ermitteln... TPmMoniControl.GetVCPCodesAvailable(HMONITOR(lbMonitorsAvailabe.Items.Objects[ lbMonitorsAvailabe.ItemIndex])); Assign(TPmMoniControl.ReqInstance); end; procedure TForm1.Assign(ASource: TPersistent); var i: Integer; LLastNodeAdded: TTreeNode; procedure AddChilds(AParent: TTreeNode; AValues: TStrings); var i: Integer; begin for i := 0 to AValues.Count-1 do tvCodes.Items.AddChild(AParent, AValues[i]); end; begin if (ASource <> nil) AND (ASource.InheritsFrom(TPmMoniControl)) then begin tvCodes.Items.Clear; for i := 0 to TPmMoniControl(ASource).CodesAvailable.Count-1 do begin LLastNodeAdded := tvCodes.Items.AddChild(nil, TPmMoniControl(ASource).CodesAvailable[i]); if TPmMoniControl(ASource).CodesAvailable.Objects[i] <> nil then AddChilds(LLastNodeAdded, TStrings(TPmMoniControl(ASource).CodesAvailable.Objects[i])); end;//for i := 0 to TPmMoniControl(ASource).CodesAvailable.Count-1 do end else inherited; end; procedure TForm1.btnSendClick(Sender: TObject); var LVCPCode: Byte; LData: DWORD; begin LVCPCode := StrToInt('$' + tvCodes.Selected.Text); LData := StrToInt(eValue.Text); if not TPmMoniControl.Send(LVCPCode, LData) then RaiseLastOSError; end; procedure TForm1.actToggleMoniPower(Sender: TObject); const //although we assume that the monitor is powered on by default we store the //value visa versa for simplicity (so we do not need to set the initial //powerstate to True [1] in the actions .Tag-property) konPowerValue: Array[Boolean] of Byte = (1, 4); var LMoniNumber, LPowerState: Byte; begin //the Monitor number is set in the .Tag property at designtime! LMoniNumber := Lo(TAction(Sender).Tag); //In the High-Byte we store the power state - get it here LPowerState := Hi(TAction(Sender).Tag); //at least the monitor should be "detected" Assert(lbMonitorsAvailabe.Items.Count >= LMoniNumber); //toogle the the powerstate - if it's True (1) set to False (0) and visa versa LPowerState := Ord(NOT Boolean(LPowerState)); //Get VCP Codes via the HMonitor handle TPmMoniControl.GetVCPCodesAvailable(HMonitor( lbMonitorsAvailabe.Items.Objects[LMoniNumber-1])); //Send new power state value TPmMoniControl.Send($D6, konPowerValue[Boolean(LPowerState)]); //Save the new power state if it could be send to the monitor TAction(Sender).Tag := MakeWord(LMoniNumber, LPowerState); end; |
AW: Multi-Monitor-Umgebung: Bestimmten Monitor abschalten
Ich muss vor dem oben stehenden Code warnen. Er ist unvollständig. Bei dem Versuch herauszufinden wie er funktioniert hab ich auf meinem ersten Monitor, wie es scheint, den Gamma-Wert so hoch geschraubt, dass er beinahe nur noch weiss ist und mein zweiter Monitor ist rosa eingefärbt.
Wie stellt man auf default zurück? Toni |
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:25 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz