У меня создается впечатление, что вы снимаете для того, чтобы сфотографировать реальный рабочий стол (с обоями и значками), и ничего больше.
1) Вызовите ToggleDesktop () в Shell32, используя COM
2) Используйте Graphics.CopyFromScreen для копирования текущей области рабочего стола
3) Вызовите ToggleDesktop (), чтобы восстановить предыдущее состояние рабочего стола
Редактировать: Да, вызов MinimizeAll () воинственный.
Вот обновленная версия, которую я взбил вместе:
/// <summary>
/// Minimizes all running applications and captures desktop as image
/// Note: Requires reference to "Microsoft Shell Controls and Automation"
/// </summary>
/// <returns>Image of desktop</returns>
private Image CaptureDesktopImage() {
//May want to play around with the delay.
TimeSpan ToggleDesktopDelay = new TimeSpan(0, 0, 0, 0, 150);
Shell32.ShellClass ShellReference = null;
Bitmap WorkingImage = null;
Graphics WorkingGraphics = null;
Rectangle TargetArea = Screen.PrimaryScreen.WorkingArea;
Image ReturnImage = null;
try
{
ShellReference = new Shell32.ShellClass();
ShellReference.ToggleDesktop();
System.Threading.Thread.Sleep(ToggleDesktopDelay);
WorkingImage = new Bitmap(TargetArea.Width,
TargetArea.Height);
WorkingGraphics = Graphics.FromImage(WorkingImage);
WorkingGraphics.CopyFromScreen(TargetArea.X, TargetArea.X, 0, 0, TargetArea.Size);
System.Threading.Thread.Sleep(ToggleDesktopDelay);
ShellReference.ToggleDesktop();
ReturnImage = (Image)WorkingImage.Clone();
}
catch
{
System.Diagnostics.Debugger.Break();
//...
}
finally
{
WorkingGraphics.Dispose();
WorkingImage.Dispose();
}
return ReturnImage;
}
Отрегулируйте по вкусу для сценариев с несколькими мониторами (хотя, похоже, это должно работать для вашего приложения).