Graphics.CopyFromScreen Graphics.CopyFromScreen Graphics.CopyFromScreen Graphics.CopyFromScreen Method

Определение

Выполняет перемещение набора битов данных о цвете с экрана на поверхность рисования объекта Graphics.Performs a bit-block transfer of color data from the screen to the drawing surface of the Graphics.

Перегрузки

CopyFromScreen(Int32, Int32, Int32, Int32, Size) CopyFromScreen(Int32, Int32, Int32, Int32, Size) CopyFromScreen(Int32, Int32, Int32, Int32, Size) CopyFromScreen(Int32, Int32, Int32, Int32, Size)

Выполняет передачу данных о цвете, соответствующих прямоугольной области пикселей, блоками битов с экрана на поверхность рисования объекта Graphics.Performs a bit-block transfer of the color data, corresponding to a rectangle of pixels, from the screen to the drawing surface of the Graphics.

CopyFromScreen(Int32, Int32, Int32, Int32, Size, CopyPixelOperation) CopyFromScreen(Int32, Int32, Int32, Int32, Size, CopyPixelOperation) CopyFromScreen(Int32, Int32, Int32, Int32, Size, CopyPixelOperation)

Выполняет передачу данных о цвете, соответствующих прямоугольной области пикселей, блоками битов с экрана на поверхность рисования объекта Graphics.Performs a bit-block transfer of the color data, corresponding to a rectangle of pixels, from the screen to the drawing surface of the Graphics.

CopyFromScreen(Point, Point, Size) CopyFromScreen(Point, Point, Size) CopyFromScreen(Point, Point, Size) CopyFromScreen(Point, Point, Size)

Выполняет перемещение набора битов данных о цвете, соответствующих прямоугольнику пикселей, с экрана на поверхность рисования объекта Graphics.Performs a bit-block transfer of color data, corresponding to a rectangle of pixels, from the screen to the drawing surface of the Graphics.

CopyFromScreen(Point, Point, Size, CopyPixelOperation) CopyFromScreen(Point, Point, Size, CopyPixelOperation) CopyFromScreen(Point, Point, Size, CopyPixelOperation)

Выполняет перемещение набора битов данных о цвете, соответствующих прямоугольнику пикселей, с экрана на поверхность рисования объекта Graphics.Performs a bit-block transfer of color data, corresponding to a rectangle of pixels, from the screen to the drawing surface of the Graphics.

CopyFromScreen(Int32, Int32, Int32, Int32, Size) CopyFromScreen(Int32, Int32, Int32, Int32, Size) CopyFromScreen(Int32, Int32, Int32, Int32, Size) CopyFromScreen(Int32, Int32, Int32, Int32, Size)

Выполняет передачу данных о цвете, соответствующих прямоугольной области пикселей, блоками битов с экрана на поверхность рисования объекта Graphics.Performs a bit-block transfer of the color data, corresponding to a rectangle of pixels, from the screen to the drawing surface of the Graphics.

public:
 void CopyFromScreen(int sourceX, int sourceY, int destinationX, int destinationY, System::Drawing::Size blockRegionSize);
public void CopyFromScreen (int sourceX, int sourceY, int destinationX, int destinationY, System.Drawing.Size blockRegionSize);
member this.CopyFromScreen : int * int * int * int * System.Drawing.Size -> unit
Public Sub CopyFromScreen (sourceX As Integer, sourceY As Integer, destinationX As Integer, destinationY As Integer, blockRegionSize As Size)

Параметры

sourceX
Int32 Int32 Int32 Int32

Координата X точки в верхнем левом углу исходного прямоугольника.The x-coordinate of the point at the upper-left corner of the source rectangle.

sourceY
Int32 Int32 Int32 Int32

Координата Y точки в верхнем левом углу исходного прямоугольника.The y-coordinate of the point at the upper-left corner of the source rectangle.

destinationX
Int32 Int32 Int32 Int32

Координата X точки в верхнем левом углу конечного прямоугольника.The x-coordinate of the point at the upper-left corner of the destination rectangle.

destinationY
Int32 Int32 Int32 Int32

Координата Y точки в верхнем левом углу конечного прямоугольника.The y-coordinate of the point at the upper-left corner of the destination rectangle.

blockRegionSize
Size Size Size Size

Размер передаваемой области.The size of the area to be transferred.

Исключения

Операция выполнена со сбоем.The operation failed.

Примеры

В следующем примере кода показано, CopyFromScreen как использовать для печати копии текущей формы.The following code example demonstrates how to use the CopyFromScreen for printing a copy of the current form.


using System;
using System.Windows.Forms;
using System.Drawing;
using System.Drawing.Printing;

public class Form1 :
    Form
{
    private Button printButton = new Button();
    private PrintDocument printDocument1 = new PrintDocument();

    public Form1()
    {
        printButton.Text = "Print Form";
        printButton.Click += new EventHandler(printButton_Click);
        printDocument1.PrintPage += new PrintPageEventHandler(printDocument1_PrintPage);
        this.Controls.Add(printButton);
    }

    void printButton_Click(object sender, EventArgs e)
    {
        CaptureScreen();
        printDocument1.Print();
    }


    Bitmap memoryImage;

    private void CaptureScreen()
    {
        Graphics myGraphics = this.CreateGraphics();
        Size s = this.Size;
        memoryImage = new Bitmap(s.Width, s.Height, myGraphics);
        Graphics memoryGraphics = Graphics.FromImage(memoryImage);
        memoryGraphics.CopyFromScreen(this.Location.X, this.Location.Y, 0, 0, s);
    }

    private void printDocument1_PrintPage(System.Object sender,  
           System.Drawing.Printing.PrintPageEventArgs e)
    {
        e.Graphics.DrawImage(memoryImage, 0, 0);
    }

  

    public static void Main()
    {
        Application.Run(new Form1());
    }
}
Imports System.Windows.Forms
Imports System.Drawing
Imports System.Drawing.Printing

Public Class Form1
    Inherits Form
    Private WithEvents printButton As New Button
    Private WithEvents printDocument1 As New PrintDocument

    Public Sub New()
        printButton.Text = "Print Form"
        Me.Controls.Add(printButton)
    End Sub

    Dim memoryImage As Bitmap

    Private Sub CaptureScreen()
        Dim myGraphics As Graphics = Me.CreateGraphics()
        Dim s As Size = Me.Size
        memoryImage = New Bitmap(s.Width, s.Height, myGraphics)
        Dim memoryGraphics As Graphics = Graphics.FromImage(memoryImage)
        memoryGraphics.CopyFromScreen(Me.Location.X, Me.Location.Y, 0, 0, s)
    End Sub

    Private Sub printDocument1_PrintPage(ByVal sender As System.Object, _
       ByVal e As System.Drawing.Printing.PrintPageEventArgs) Handles _
       printDocument1.PrintPage
        e.Graphics.DrawImage(memoryImage, 0, 0)
    End Sub

    Private Sub printButton_Click(ByVal sender As System.Object, ByVal e As _
       System.EventArgs) Handles printButton.Click
        CaptureScreen()
        printDocument1.Print()
    End Sub

    Public Shared Sub Main()
        Application.Run(New Form1())
    End Sub
End Class

Комментарии

CopyFromScreen Методы полезны для создания слоев одного изображения поверх другого.The CopyFromScreen methods are useful for layering one image on top of another. Чтобы указать способ смешивания цветов источника и назначения, используйте один из CopyFromScreen методов, CopyPixelOperation принимающих параметр.To specify how the source and destination colors are blended, use one of the CopyFromScreen methods that takes a CopyPixelOperation parameter.

Безопасность

UIPermission
для доступа ко всем окнам.for access to all windows. Связанное перечисление: AllWindows.Related enumeration: AllWindows.

Дополнительно

CopyFromScreen(Int32, Int32, Int32, Int32, Size, CopyPixelOperation) CopyFromScreen(Int32, Int32, Int32, Int32, Size, CopyPixelOperation) CopyFromScreen(Int32, Int32, Int32, Int32, Size, CopyPixelOperation)

Выполняет передачу данных о цвете, соответствующих прямоугольной области пикселей, блоками битов с экрана на поверхность рисования объекта Graphics.Performs a bit-block transfer of the color data, corresponding to a rectangle of pixels, from the screen to the drawing surface of the Graphics.

public:
 void CopyFromScreen(int sourceX, int sourceY, int destinationX, int destinationY, System::Drawing::Size blockRegionSize, System::Drawing::CopyPixelOperation copyPixelOperation);
public void CopyFromScreen (int sourceX, int sourceY, int destinationX, int destinationY, System.Drawing.Size blockRegionSize, System.Drawing.CopyPixelOperation copyPixelOperation);
member this.CopyFromScreen : int * int * int * int * System.Drawing.Size * System.Drawing.CopyPixelOperation -> unit

Параметры

sourceX
Int32 Int32 Int32 Int32

Координата X точки в верхнем левом углу исходного прямоугольника.The x-coordinate of the point at the upper-left corner of the source rectangle.

sourceY
Int32 Int32 Int32 Int32

Координата Y точки в верхнем левом углу исходного прямоугольника.The y-coordinate of the point at the upper-left corner of the source rectangle

destinationX
Int32 Int32 Int32 Int32

Координата X точки в верхнем левом углу конечного прямоугольника.The x-coordinate of the point at the upper-left corner of the destination rectangle.

destinationY
Int32 Int32 Int32 Int32

Координата Y точки в верхнем левом углу конечного прямоугольника.The y-coordinate of the point at the upper-left corner of the destination rectangle.

blockRegionSize
Size Size Size Size

Размер передаваемой области.The size of the area to be transferred.

copyPixelOperation
CopyPixelOperation CopyPixelOperation CopyPixelOperation CopyPixelOperation

Одно из значений CopyPixelOperation.One of the CopyPixelOperation values.

Исключения

copyPixelOperation не является членом CopyPixelOperation.copyPixelOperation is not a member of CopyPixelOperation.

Операция выполнена со сбоем.The operation failed.

Примеры

В следующем примере показано использование метода CopyFromScreen.The following example demonstrates how to use the CopyFromScreen method. Чтобы выполнить этот пример, вставьте его в форму Windows Forms.To run this example, paste it into a Windows Form. Обработайте Paint событие формы и вызовите CopyPixels4 метод из Paint метода обработки событий, передав e его как PaintEventArgs.Handle the form's Paint event and call the CopyPixels4 method from the Paint event-handling method, passing e as PaintEventArgs.

private void CopyPixels4(PaintEventArgs e)
{
    e.Graphics.CopyFromScreen(0, 0, 20, 20, new Size(160, 160), 
        CopyPixelOperation.SourceInvert);
}
Private Sub CopyPixels4(ByVal e As PaintEventArgs) 
    e.Graphics.CopyFromScreen(0, 0, 20, 20, _
        New Size(160, 160), CopyPixelOperation.SourceInvert)
End Sub

Комментарии

CopyFromScreen Методы полезны для создания слоев одного изображения поверх другого.The CopyFromScreen methods are useful for layering one image on top of another. copyPixelOperation Параметр позволяет указать, следует ли смешивать цвета источника с цветами в области назначения.The copyPixelOperation parameter allows you to specify if and how the source colors should be blended with the colors in the destination area.

Безопасность

UIPermission
для доступа ко всем окнам.for access to all windows. Связанное перечисление: AllWindows.Related enumeration: AllWindows.

Дополнительно

CopyFromScreen(Point, Point, Size) CopyFromScreen(Point, Point, Size) CopyFromScreen(Point, Point, Size) CopyFromScreen(Point, Point, Size)

Выполняет перемещение набора битов данных о цвете, соответствующих прямоугольнику пикселей, с экрана на поверхность рисования объекта Graphics.Performs a bit-block transfer of color data, corresponding to a rectangle of pixels, from the screen to the drawing surface of the Graphics.

public:
 void CopyFromScreen(System::Drawing::Point upperLeftSource, System::Drawing::Point upperLeftDestination, System::Drawing::Size blockRegionSize);
public void CopyFromScreen (System.Drawing.Point upperLeftSource, System.Drawing.Point upperLeftDestination, System.Drawing.Size blockRegionSize);
member this.CopyFromScreen : System.Drawing.Point * System.Drawing.Point * System.Drawing.Size -> unit
Public Sub CopyFromScreen (upperLeftSource As Point, upperLeftDestination As Point, blockRegionSize As Size)

Параметры

upperLeftSource
Point Point Point Point

Точка в верхнем левом углу исходного прямоугольника.The point at the upper-left corner of the source rectangle.

upperLeftDestination
Point Point Point Point

Точка в верхнем левом углу целевого прямоугольника.The point at the upper-left corner of the destination rectangle.

blockRegionSize
Size Size Size Size

Размер передаваемой области.The size of the area to be transferred.

Исключения

Операция выполнена со сбоем.The operation failed.

Примеры

В следующем примере показано использование метода CopyFromScreen.The following example demonstrates how to use the CopyFromScreen method. Чтобы выполнить этот пример, вставьте его в форму Windows Forms.To run this example, paste it into a Windows Form. Обработайте Paint событие формы и вызовите CopyPixels1 метод из Paint метода обработки событий, передав e его как PaintEventArgs.Handle the form's Paint event and call the CopyPixels1 method from the Paint event-handling method, passing e as PaintEventArgs.

private void CopyPixels1(PaintEventArgs e)
{
    e.Graphics.CopyFromScreen(this.Location, 
        new Point(40, 40), new Size(100, 100));
}
Private Sub CopyPixels1(ByVal e As PaintEventArgs) 
    e.Graphics.CopyFromScreen(Me.Location, _
        New Point(40, 40), New Size(100, 100))

End Sub

Комментарии

CopyFromScreen Методы полезны для создания слоев одного изображения поверх другого.The CopyFromScreen methods are useful for layering one image on top of another. Чтобы указать способ смешивания цветов источника и назначения, используйте один из CopyFromScreen методов, CopyPixelOperation принимающих параметр.To specify how the source and destination colors are blended, use one of the CopyFromScreen methods that takes a CopyPixelOperation parameter.

Безопасность

UIPermission
для доступа ко всем окнам.for access to all windows. Связанное перечисление: AllWindows.Related enumeration: AllWindows.

Дополнительно

CopyFromScreen(Point, Point, Size, CopyPixelOperation) CopyFromScreen(Point, Point, Size, CopyPixelOperation) CopyFromScreen(Point, Point, Size, CopyPixelOperation)

Выполняет перемещение набора битов данных о цвете, соответствующих прямоугольнику пикселей, с экрана на поверхность рисования объекта Graphics.Performs a bit-block transfer of color data, corresponding to a rectangle of pixels, from the screen to the drawing surface of the Graphics.

public:
 void CopyFromScreen(System::Drawing::Point upperLeftSource, System::Drawing::Point upperLeftDestination, System::Drawing::Size blockRegionSize, System::Drawing::CopyPixelOperation copyPixelOperation);
public void CopyFromScreen (System.Drawing.Point upperLeftSource, System.Drawing.Point upperLeftDestination, System.Drawing.Size blockRegionSize, System.Drawing.CopyPixelOperation copyPixelOperation);
member this.CopyFromScreen : System.Drawing.Point * System.Drawing.Point * System.Drawing.Size * System.Drawing.CopyPixelOperation -> unit

Параметры

upperLeftSource
Point Point Point Point

Точка в верхнем левом углу исходного прямоугольника.The point at the upper-left corner of the source rectangle.

upperLeftDestination
Point Point Point Point

Точка в верхнем левом углу целевого прямоугольника.The point at the upper-left corner of the destination rectangle.

blockRegionSize
Size Size Size Size

Размер передаваемой области.The size of the area to be transferred.

copyPixelOperation
CopyPixelOperation CopyPixelOperation CopyPixelOperation CopyPixelOperation

Одно из значений перечисления CopyPixelOperation.One of the CopyPixelOperation values.

Исключения

copyPixelOperation не является членом CopyPixelOperation.copyPixelOperation is not a member of CopyPixelOperation.

Операция выполнена со сбоем.The operation failed.

Примеры

В следующем примере показано использование метода CopyFromScreen.The following example demonstrates how to use the CopyFromScreen method. Чтобы выполнить этот пример, вставьте его в форму Windows Forms.To run this example, paste it into a Windows Form. Обработайте Paint событие формы и вызовите CopyPixels2 метод из Paint метода обработки событий, передав e его как PaintEventArgs.Handle the form's Paint event and call the CopyPixels2 method from the Paint event-handling method, passing e as PaintEventArgs.

private void CopyPixels2(PaintEventArgs e)
{
    e.Graphics.CopyFromScreen(this.Location, new Point(40, 40), 
        new Size(100, 100), CopyPixelOperation.MergePaint); 
}
Private Sub CopyPixels2(ByVal e As PaintEventArgs) 
    e.Graphics.CopyFromScreen(Me.Location, _
        New Point(40, 40), New Size(100, 100), _
        CopyPixelOperation.MergePaint)
End Sub

Комментарии

CopyFromScreen Методы полезны для создания слоев одного изображения поверх другого.The CopyFromScreen methods are useful for layering one image on top of another. copyPixelOperation Параметр позволяет указать, следует ли смешивать цвета источника с цветами в области назначения.The copyPixelOperation parameter allows you to specify if and how the source colors should be blended with the colors in the destination area.

Безопасность

UIPermission
для доступа ко всем окнам.for access to all windows. Связанное перечисление: AllWindows.Related enumeration: AllWindows.

Дополнительно

Применяется к