原文 http://www.cnblogs.com/coolkiss/archive/2013/09/18/3328854.html

经过google加各种百度,终于找到了一个有效的解决方案,下面是两个主要类,方便后人使用

1. Win32 API, 需要添加其它内容可以到这个网站从查找对应的c#实现

    public class WinApi
{
public const Int32 CCHDEVICENAME = ;
public const Int32 CCHFORMNAME = ; public enum DEVMODE_SETTINGS
{
ENUM_CURRENT_SETTINGS = (-),
ENUM_REGISTRY_SETTINGS = (-)
}
[Flags()]
public enum DisplayDeviceStateFlags : int
{
/// <summary>The device is part of the desktop.</summary>
AttachedToDesktop = 0x1,
MultiDriver = 0x2,
/// <summary>The device is part of the desktop.</summary>
PrimaryDevice = 0x4,
/// <summary>Represents a pseudo device used to mirror application drawing for remoting or other purposes.</summary>
MirroringDriver = 0x8,
/// <summary>The device is VGA compatible.</summary>
VGACompatible = 0x10,
/// <summary>The device is removable; it cannot be the primary display.</summary>
Removable = 0x20,
/// <summary>The device has more display modes than its output devices support.</summary>
ModesPruned = 0x8000000,
Remote = 0x4000000,
Disconnect = 0x2000000
} public enum Display_Device_Stateflags
{
DISPLAY_DEVICE_ATTACHED_TO_DESKTOP = 0x1,
DISPLAY_DEVICE_MIRRORING_DRIVER = 0x8,
DISPLAY_DEVICE_MODESPRUNED = 0x8000000,
DISPLAY_DEVICE_MULTI_DRIVER = 0x2,
DISPLAY_DEVICE_PRIMARY_DEVICE = 0x4,
DISPLAY_DEVICE_VGA_COMPATIBLE = 0x10
} public enum DeviceFlags
{
CDS_FULLSCREEN = 0x4,
CDS_GLOBAL = 0x8,
CDS_NORESET = 0x10000000,
CDS_RESET = 0x40000000,
CDS_SET_PRIMARY = 0x10,
CDS_TEST = 0x2,
CDS_UPDATEREGISTRY = 0x1,
CDS_VIDEOPARAMETERS = 0x20,
} public enum DEVMODE_Flags
{
DM_BITSPERPEL = 0x40000,
DM_DISPLAYFLAGS = 0x200000,
DM_DISPLAYFREQUENCY = 0x400000,
DM_PELSHEIGHT = 0x100000,
DM_PELSWIDTH = 0x80000,
DM_POSITION = 0x20
} public enum DisplaySetting_Results
{
DISP_CHANGE_BADFLAGS = -,
DISP_CHANGE_BADMODE = -,
DISP_CHANGE_BADPARAM = -,
DISP_CHANGE_FAILED = -,
DISP_CHANGE_NOTUPDATED = -,
DISP_CHANGE_RESTART = ,
DISP_CHANGE_SUCCESSFUL =
} [StructLayout(LayoutKind.Sequential)]
public struct POINTL
{
[MarshalAs(UnmanagedType.I4)]
public int x;
[MarshalAs(UnmanagedType.I4)]
public int y;
} [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
public struct DEVMODE
{
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = )]
public string dmDeviceName; [MarshalAs(UnmanagedType.U2)]
public UInt16 dmSpecVersion; [MarshalAs(UnmanagedType.U2)]
public UInt16 dmDriverVersion; [MarshalAs(UnmanagedType.U2)]
public UInt16 dmSize; [MarshalAs(UnmanagedType.U2)]
public UInt16 dmDriverExtra; [MarshalAs(UnmanagedType.U4)]
public DEVMODE_Flags dmFields; public POINTL dmPosition; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmDisplayOrientation; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmDisplayFixedOutput; [MarshalAs(UnmanagedType.I2)]
public Int16 dmColor; [MarshalAs(UnmanagedType.I2)]
public Int16 dmDuplex; [MarshalAs(UnmanagedType.I2)]
public Int16 dmYResolution; [MarshalAs(UnmanagedType.I2)]
public Int16 dmTTOption; [MarshalAs(UnmanagedType.I2)]
public Int16 dmCollate; [MarshalAs(UnmanagedType.ByValTStr, SizeConst = )]
public string dmFormName; [MarshalAs(UnmanagedType.U2)]
public UInt16 dmLogPixels; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmBitsPerPel; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmPelsWidth; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmPelsHeight; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmDisplayFlags; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmDisplayFrequency; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmICMMethod; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmICMIntent; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmMediaType; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmDitherType; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmReserved1; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmReserved2; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmPanningWidth; [MarshalAs(UnmanagedType.U4)]
public UInt32 dmPanningHeight;
} [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
public struct DISPLAY_DEVICE
{
[MarshalAs(UnmanagedType.U4)]
public int cb;
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = )]
public string DeviceName;
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = )]
public string DeviceString;
[MarshalAs(UnmanagedType.U4)]
public DisplayDeviceStateFlags StateFlags;
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = )]
public string DeviceID;
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = )]
public string DeviceKey;
} public class User_32
{
[DllImport("user32.dll")]
public static extern int ChangeDisplaySettings(ref DEVMODE devMode, int flags); //[DllImport("user32.dll")]
//public static extern int ChangeDisplaySettingsEx(ref DEVMODE devMode, int flags); [DllImport("user32.dll")]
public static extern int ChangeDisplaySettingsEx(string lpszDeviceName, [In] ref DEVMODE lpDevMode, IntPtr hwnd, int dwFlags, IntPtr lParam); [DllImport("user32.dll")]
public static extern bool EnumDisplayDevices(string lpDevice, int iDevNum, ref DISPLAY_DEVICE lpDisplayDevice, int dwFlags); [DllImport("user32.dll")]
public static extern int EnumDisplaySettings(string deviceName, int modeNum, ref DEVMODE devMode);
} }

2. 更新主屏幕类

    public class ScreenHelper
{
public static List<Screen> GetAllScreen()
{
List<WinApi.DISPLAY_DEVICE> devices = new List<WinApi.DISPLAY_DEVICE>();
List<Screen> screens = new List<Screen>();
bool error = false;
//Here I am listing all DisplayDevices (Monitors)
for (int devId = ; !error; devId++)
{
try
{
WinApi.DISPLAY_DEVICE device = new WinApi.DISPLAY_DEVICE();
device.cb = Marshal.SizeOf(typeof(WinApi.DISPLAY_DEVICE));
error = !WinApi.User_32.EnumDisplayDevices(null, devId, ref device, );
if ((device.StateFlags & WinApi.DisplayDeviceStateFlags.AttachedToDesktop) == WinApi.DisplayDeviceStateFlags.AttachedToDesktop)
{
devices.Add(device);
}
}
catch (Exception)
{
error = true;
}
} devices.ForEach(d => {
WinApi.DEVMODE ndm = NewDevMode();
WinApi.User_32.EnumDisplaySettings(d.DeviceName, (int)WinApi.DEVMODE_SETTINGS.ENUM_REGISTRY_SETTINGS, ref ndm);
screens.Add(new Screen() {
DeviceMode = ndm,
ScreenDevice = d,
DeviceName = d.DeviceName,
IsPrimary = ((d.StateFlags & WinApi.DisplayDeviceStateFlags.PrimaryDevice) == WinApi.DisplayDeviceStateFlags.PrimaryDevice),
ScreenWidth = (int)ndm.dmPelsWidth,
ScreenHeight = (int)ndm.dmPelsHeight,
XPosition = (int)ndm.dmPosition.x,
YPosition = (int)ndm.dmPosition.y
});
}); return screens;
} public static void SetPrimaryScreen(string deviceName)
{
List<Screen> screenList = GetAllScreen();
Screen primaryScreen = GetPrimaryScreen(screenList);
if (primaryScreen.ScreenDevice.DeviceName == deviceName)
return; Screen newPrimaryScreen = GetScreen(deviceName); SwitchPrimaryScreen(newPrimaryScreen, primaryScreen); } public static Screen GetPrimaryScreen(List<Screen> devices)
{
foreach (Screen d in devices)
{
if ((d.ScreenDevice.StateFlags & WinApi.DisplayDeviceStateFlags.PrimaryDevice) == WinApi.DisplayDeviceStateFlags.PrimaryDevice)
{
return d;
}
}
return null;
} public static List<Screen> GetUnPrimaryScreen(List<Screen> devices)
{
List<Screen> dList = new List<Screen>(); foreach (Screen d in devices)
{
if ((d.ScreenDevice.StateFlags & WinApi.DisplayDeviceStateFlags.PrimaryDevice) != WinApi.DisplayDeviceStateFlags.PrimaryDevice)
{
dList.Add(d);
}
}
return dList;
} public static Screen GetScreen(string deviceName)
{
List<Screen> screenList = GetAllScreen();
return screenList.Where(p => p.ScreenDevice.DeviceName == deviceName).FirstOrDefault();
} private static void SwitchPrimaryScreen(Screen newPrimary, Screen oldPrimary)
{
MoveOldPrimary(newPrimary, oldPrimary);
MoveNewPrimary(newPrimary, oldPrimary);
CommitChange(newPrimary, oldPrimary);
} private static void MoveOldPrimary(Screen newPrimary, Screen oldPrimary)
{
WinApi.DEVMODE ndm3 = NewDevMode();
ndm3.dmFields = WinApi.DEVMODE_Flags.DM_POSITION;
ndm3.dmPosition.x = (int)newPrimary.DeviceMode.dmPelsWidth;
ndm3.dmPosition.y = ; WinApi.User_32.ChangeDisplaySettingsEx(oldPrimary.ScreenDevice.DeviceName, ref ndm3, (IntPtr)null, (int)WinApi.DeviceFlags.CDS_UPDATEREGISTRY | (int)WinApi.DeviceFlags.CDS_NORESET, IntPtr.Zero); } private static void MoveNewPrimary(Screen newPrimary, Screen oldPrimary)
{
WinApi.DEVMODE ndm4 = NewDevMode();
ndm4.dmFields = WinApi.DEVMODE_Flags.DM_POSITION;
ndm4.dmPosition.x = ;
ndm4.dmPosition.y = ;
WinApi.User_32.ChangeDisplaySettingsEx(newPrimary.ScreenDevice.DeviceName, ref ndm4, (IntPtr)null, (int)WinApi.DeviceFlags.CDS_SET_PRIMARY | (int)WinApi.DeviceFlags.CDS_UPDATEREGISTRY | (int)WinApi.DeviceFlags.CDS_NORESET, IntPtr.Zero);
} private static void CommitChange(Screen newPrimary, Screen oldPrimary)
{
WinApi.DEVMODE ndm5 = NewDevMode();
WinApi.User_32.ChangeDisplaySettingsEx(oldPrimary.ScreenDevice.DeviceName, ref ndm5, (IntPtr)null, (int)WinApi.DeviceFlags.CDS_UPDATEREGISTRY, (IntPtr)null); WinApi.DEVMODE ndm6 = NewDevMode();
WinApi.User_32.ChangeDisplaySettingsEx(newPrimary.ScreenDevice.DeviceName, ref ndm6, (IntPtr)null, (int)WinApi.DeviceFlags.CDS_SET_PRIMARY | (int)WinApi.DeviceFlags.CDS_UPDATEREGISTRY, IntPtr.Zero);
} private static WinApi.DEVMODE NewDevMode()
{
WinApi.DEVMODE dm = new WinApi.DEVMODE();
dm.dmDeviceName = new String(new char[]);
dm.dmFormName = new String(new char[]);
dm.dmSize = (ushort)Marshal.SizeOf(dm);
return dm;
}
}

c# 多显示器设置主屏幕(Set primary screen for multiple monitors)的更多相关文章

  1. 关于在Safari浏览器中将网页添加到主屏幕的相关设置(自定义图标,启动动画,自定义名称)

    在ios中我们可以使用Safari浏览自带的将网页添加到主屏幕上,让我们的web页面看起来像native那样 第一步: 第二步: 第三步: 到这里还没结束:我们还要进行相关设置才能使我们的应用更像原生 ...

  2. 在CentOS 7 / Gnome 3 双屏时设置主屏

    在Windows中设置扩展显示器为主屏的方式非常清楚,但在Linux中就不是那么明显了,下面介绍如何完成这个设置 ------------------------------------------- ...

  3. C#操作电脑多显示器设置

    电脑多显示器设置 第一种方式 通过使用api函数SetDisplayConfig来设置.这种方式在某些电脑中设置有几率会导致电脑黑屏 使用代码如下: private const uint SDC_AP ...

  4. PL/SQL设置主键自增

    oracle没有设置主键auto increment的功能,需要自己编写序列和触发器实现主键自动递增. 示例: 创建表menu:   一.创建表 create table menu( menuId n ...

  5. Django数据库怎么给字段设置主键

    id = models.IntegerField(primary_key = True) 附: null :缺省设置为false.通常不将其用于字符型字段上,比如CharField,TextField ...

  6. SQL语句建表、设置主键、外键、check、default、unique约束

    · 什么是数据库? 存放数据的仓库. · 数据库和数据结构有什么区别? 数据结构要解决在内存中操作数据的问题,数据库要解决在硬盘中操作数据的问题.数据结构研究一些抽象数据模型(ADT)和以及定义在该模 ...

  7. iOS中为网站添加图标到主屏幕以及增加启动画面

    虽然没有能力开发Native App,但还是可以利用iOS中Safari浏览器的特性小小的折腾一下,做一个伪Web App满足下小小的虚荣心的. 既然是在iOS中的Safari折腾的,那么代码中利用到 ...

  8. windows系统操作类和演示程序(关机,关闭显示器,打开屏幕保护程序,打开光驱等)

    /// <summary> /// 系统控制类,关机,关闭显示器,打开屏幕保存程序等 /// </summary> public class SystemPowerContro ...

  9. 关于oracle设置主键自增的问题

    关于orcale设置主键自增的问题 关于主键Oracle中并没有提供一个直接的语句设置,对于这个oralce一般都是用序列和触发器来实现 一下又两种方法来实现 一 ,不使用触发器 创建序列: crea ...

随机推荐

  1. knockoutjs简单使用

    knockoutjs是一个不错的前端MVVM框架,极大的减轻了前端工作开发量,增加前端代码的维护性.主要特点:声明式绑定.依赖跟踪.模块开速开发. 如下代码(官方代码稍做修改) <p> 姓 ...

  2. html5介绍 之亮点特性

    html5 兴起- 乔帮助在2010年发布的:关于对flash的思考,提到有了h5放弃 flash   1 富图形,富媒体      2 本地存储     cookie   3 LBS      基于 ...

  3. 你想建设一个能承受500万PV/每天的网站吗?如果计算呢?(转)

    作者:赵磊 博客:http://elf8848.iteye.com 你想建设一个能承受500万PV/每天的网站吗? 500万PV是什么概念?服务器每秒要处理多少个请求才能应对?如果计算呢? PV是什么 ...

  4. perl 创建包

    <pre name="code" class="python"><pre name="code" class=" ...

  5. kernal linear regression

  6. ftk学习记(icon篇)

    [声明:版权全部,欢迎转载.请勿用于商业用途.  联系信箱:feixiaoxing @163.com] 在開始今天的文章之前.我们还是先看一下上一节的效果图. 大家能够參照上一节的解说,是不是存在这种 ...

  7. ASP.NET MVC4 json序列化器

    ASP.NET MVC4中调用WEB API的四个方法 2012年06月07日00:05 it168网站原创 作者:廖煜嵘 编辑:景保玉 我要评论(0) [IT168技术]当今的软件开发中,设计软件的 ...

  8. 列"xx"不在表Table中

    在数据库中用了left join来查一个表的所有列和另一个表的一个列,但无论用IDataReader还是DataSet都不能获取到另一个表的列,调试时总是说没有那个值,但在数据库中执行语句又有.一直想 ...

  9. nade.js(一)进程管理

    简介 process是一个全局内置对象,可以在代码中的任何位置访问此对象,这个对象代表我们的node.js代码宿主的操作系统进程对象. 使用process对象可以截获进程的异常.退出等事件,也可以获取 ...

  10. .net通用权限框架C/S概览

    通用权限框架cs部分 先概述一下,cs使用vs2010+sql2008 和bs公用同一个数据库 为使界面好看使用了第三方控件 donetbar和devexpress,正版是要收费的,但是你们都明白的可 ...