Using Win32 functions in Visual FoxPro Image Gallery
Code examples:
Custom GDI+ class
How to change display settings: screen resolution, screen refresh rate
CryptoAPI: retrieving list of providers
Adding an ODBC data source with the SQLConfigDataSource; use automatic or interactive mode
Winsock: sending email messages (SMTP, port 25)
Creating a clipping region from the path selected into the device context of a form
Adding and deleting User Accounts
Custom HttpRequest class (WinHTTP)
Splash Screen for the VFP application
Mapping and disconnecting network drives
Adding and deleting Scheduled Tasks using NetScheduleJob API functions
Using FtpCommand
Storing screen shot of a form to bitmap file
Enumerating ODBC Data Sources available on the local computer
How to create non-blocking Winsock server
Bitmap Class for Visual FoxPro application
Building a tree of subdirectories for a given path using FindFile functions
How to change the name and the size of the font in the MessageBox dialog
HOWTO: Use the Win32 API to Access File Dates and Times
Using EnumPrinters function to enumerate locally installed printers
Using FoxTray ActiveX control: System Tray Icon and menu attached to VFP form
Using IsChild() for testing ThisForm.ShowWindow property
A client for testing non-blocking Winsock server
Establishing connection using the SQLDriverConnect
How to detect if additional monitor is connected and active

User rating: 9/10 (1 votes)
Rate this code sample:
  • ~
More code examples    Listed functions    Add comment     W32 Constants      Translate this page Printer friendly version of this code sample
Versions:
click to open
Before you begin:
Nowadays having two monitors connected to a PC becomes more a common place rather than exception. This code sample explains how to detect all available monitors through enumerating display devices and their properties.


See also:
  • How to change display settings: screen resolution, screen refresh rate
  • How to adjust monitor brightness (Vista, monitor with DDC support)
  • using System;
    using System.Runtime.InteropServices;
    using System.Windows.Forms;
    
    namespace ConsoleApplication1
    {
        partial class Program
        {
            public const int ENUM_CURRENT_SETTINGS = -1;
    
            [StructLayout(LayoutKind.Sequential)]
            public struct DISPLAY_DEVICE
            {
                public int cb;
                [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
                public string DeviceName;
                [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 128)]
                public string DeviceString;
                public int StateFlags;
                [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 128)]
                public string DeviceID;
                [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 128)]
                public string DeviceKey;
    
                public DISPLAY_DEVICE(int flags)
                {
                    cb = 0;
                    StateFlags = flags;
                    DeviceName = new string((char)32, 32);
                    DeviceString = new string((char)32, 128);
                    DeviceID = new string((char)32, 128);
                    DeviceKey = new string((char)32, 128);
                    cb = Marshal.SizeOf(this);
                }
            }
    
            [StructLayout(LayoutKind.Sequential)]
            public struct DEVMODE
            {
                [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
                public string dmDeviceName;
                public short dmSpecVersion;
                public short dmDriverVersion;
                public short dmSize;
                public short dmDriverExtra;
                public int dmFields;
                public short dmOrientation;
                public short dmPaperSize;
                public short dmPaperLength;
                public short dmPaperWidth;
                public short dmScale;
                public short dmCopies;
                public short dmDefaultSource;
                public short dmPrintQuality;
                public short dmColor;
                public short dmDuplex;
                public short dmYResolution;
                public short dmTTOption;
                public short dmCollate;
                [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
                public string dmFormName;
                public short dmUnusedPadding;
                public short dmBitsPerPel;
                public int dmPelsWidth;
                public int dmPelsHeight;
                public int dmDisplayFlags;
                public int dmDisplayFrequency;
            }
    
            static void EnumMonitors()
            {
                foreach (Screen screen in Screen.AllScreens)
                {
                    Console.WriteLine("*** Managed output");
    
                    Console.WriteLine("Display Device: {0}\t\n" +
                        "\tBPP={1}\n\tWidth={2}\n\tHeight={3}\n\n",
                        screen.DeviceName, screen.BitsPerPixel,
                        screen.Bounds.Width, screen.Bounds.Height);
    
                    DISPLAY_DEVICE monitor =
                        new DISPLAY_DEVICE(0);
    
                    EnumDisplayDevices(screen.DeviceName, 0,
                        ref monitor, 0);
    
                    DEVMODE dm = new DEVMODE();
    
                    EnumDisplaySettings(screen.DeviceName,
                        ENUM_CURRENT_SETTINGS, ref dm);
    
                    Console.WriteLine("*** Unmanaged output");
    
                    Console.WriteLine("\tMonitor: {0}\n\t\t{1}\n\t\t{2}",
                        monitor.DeviceName, 
                        monitor.DeviceString, monitor.DeviceID);
    
                    Console.WriteLine(
                        "\t\t\tFreq.={0}\n" +
                        "\t\t\tBPP={1}\n" +
                        "\t\t\tWidth={2}\n" +
                        "\t\t\tHeight={3}\n",
                        dm.dmDisplayFrequency, dm.dmBitsPerPel,
                        dm.dmPelsWidth, dm.dmPelsHeight);
    
                }
                Console.WriteLine("Number of monitors: {0}", 
                    Screen.AllScreens.Length);
            }
    
            [DllImport("User32.dll")]
            private static extern bool EnumDisplayDevices(
                string lpDevice, int iDevNum,
                ref DISPLAY_DEVICE lpDisplayDevice, int dwFlags);
    
            [DllImport("User32.dll")]
            private static extern bool EnumDisplaySettings(
                string devName, int modeNum, ref DEVMODE devMode);
    
        }
    }
    

    User rating: 9/10 (1 votes)
    Rate this code sample:
    • ~
    4306 bytes  
    Created: 2008-12-09 14:50:37  
    Modified: 2014-01-30 13:58:32  
    Visits in 7 days: 220  
    Listed functions:
    EnumDisplayDevices
    EnumDisplaySettings
    GetMonitorInfo
    MonitorFromWindow
    Printer friendly API declarations
    My comment:
    In the cursor created by this code sample, each connected monitor is indicated by non-empty MonitorName value.

    For an active monitor (the desktop extends to such monitor), several other values are populated:

  • Screenwidth
  • Screenheight
  • Bitsperpixel
  • DsppositionX
  • DsppositionY

    From the screen dimensions and the display position it is possible to determine whether a given window is visible on a particular display.

    * * *
    Read Two monitors are better than one by Tony Northrup published on Microsoft website. Bet he might be busy writing a sequel "N+1 monitors better than N".

    * * *
    Some graphics cards and external units (Matrox) support connections to multiple monitors, three and more.
  • Word Index links for this example:
    Translate this page:
      Spanish    Portuguese    German    French    Italian  
    FreeTranslation.com offers instant, free translations of text or web pages.
    User Contributed Notes:
    There are no notes on this subject.


    Copyright 2001-2015 News2News, Inc. Before reproducing or distributing any data from this site please ask for an approval from its owner. Unless otherwise specified, this page is for your personal and non-commercial use. The information on this page is presented AS IS, meaning that you may use it at your own risk. Microsoft Visual FoxPro and Windows are trade marks of Microsoft Corp. All other trademarks are the property of their respective owners. 

    Privacy policy
    Credits: PHP (4.4.9), an HTML-embedded scripting language, MySQL (5.1.68), the Open Source standard SQL database, AceHTML Freeware Version 4, freeware HTML Editor of choice.   Hosted by Korax Online Inc.
    Last Topics Visited (54.161.147.106)
    21 sec.Function: 'JetCreateDatabase'
    Function group: 'Extensible Storage Engine (ESE, Jet Blue)'
    51 sec.Function: 'GetTickCount'
    3.22 min.Function: 'timeGetDevCaps'
    Function group: 'Windows Multimedia'
    Google
    Advertise here!