blob: e797f00fa2d5fba45bdc6cfa7bda4a63fa6be1c9 [file] [log] [blame] [raw]
// NVNC - .NET VNC Server Library
// Copyright (C) 2014 T!T@N
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
using System;
using System.Drawing;
using NVNC.Encodings;
using NVNC.Utils;
using NVNC.Utils.ScreenTree;
namespace NVNC
{
/// <summary>
/// Factory class used to create derived EncodedRectangle objects at runtime for sending to the VNC Client.
/// </summary>
public class EncodedRectangleFactory
{
VncHost rfb;
Framebuffer framebuffer;
/// <summary>
/// Creates an instance of the EncodedRectangleFactory using the connected RfbProtocol object and associated Framebuffer object.
/// </summary>
/// <param name="rfb">An RfbProtocol object that will be passed to any created EncodedRectangle objects. Must be non-null, already initialized, and connected.</param>
/// <param name="framebuffer">A Framebuffer object which will be used by any created EncodedRectangle objects in order to decode and draw rectangles locally.</param>
public EncodedRectangleFactory(VncHost rfb, Framebuffer framebuffer)
{
System.Diagnostics.Debug.Assert(rfb != null, "RfbProtocol object must be non-null");
System.Diagnostics.Debug.Assert(framebuffer != null, "Framebuffer object must be non-null");
this.rfb = rfb;
this.framebuffer = framebuffer;
}
public EncodedRectangle Build(QuadNode node, VncHost.Encoding encoding)
{
int[] pixels = node.NodeData;
EncodedRectangle e;
switch (encoding)
{
case VncHost.Encoding.RawEncoding:
e = new RawRectangle(rfb, framebuffer, pixels, node.Bounds);
break;
case VncHost.Encoding.CopyRectEncoding:
e = new CopyRectRectangle(rfb, framebuffer, node.Bounds);
break;
case VncHost.Encoding.RreEncoding:
e = new RreRectangle(rfb, framebuffer, pixels, node.Bounds);
break;
case VncHost.Encoding.CoRreEncoding:
e = new CoRreRectangle(rfb, framebuffer, pixels, node.Bounds);
break;
case VncHost.Encoding.HextileEncoding:
e = new HextileRectangle(rfb, framebuffer, pixels, node.Bounds);
break;
case VncHost.Encoding.ZrleEncoding:
e = new ZrleRectangle(rfb, framebuffer, pixels, node.Bounds);
break;
case VncHost.Encoding.ZlibEncoding:
e = new ZlibRectangle(rfb, framebuffer, pixels, node.Bounds);
break;
default:
// Sanity check
throw new Exception("Unsupported Encoding Format received: " + encoding + ".");
}
return e;
}
/// <summary>
/// Creates an object type derived from EncodedRectangle, based on the value of encoding.
/// </summary>
/// <param name="rectangle">A node object from the Screen Handler defining the bounds of the rectangle and the pixel data. IT SHOULD BE CONSIDERED LOCALLY AGAINST pixels param, not globally against the screen size</param>
/// <param name="encoding">An Integer indicating the encoding type to be used for this rectangle. Used to determine the type of EncodedRectangle to create.</param>
/// <returns></returns>
public EncodedRectangle Build(Rectangle2 rectangle, VncHost.Encoding encoding)
{
Bitmap bmp = PixelGrabber.CreateScreenCapture(rectangle.ToRectangle());
int[] pixels = PixelGrabber.GrabPixels(bmp, rectangle.X, rectangle.Y, rectangle.Width, rectangle.Height, bmp.PixelFormat);
return Build(rectangle, pixels, encoding);
}
public EncodedRectangle Build(Rectangle2 rectangle, int[] pixels, VncHost.Encoding encoding)
{
EncodedRectangle e;
switch (encoding)
{
case VncHost.Encoding.RawEncoding:
e = new RawRectangle(rfb, framebuffer, pixels, rectangle);
break;
case VncHost.Encoding.CopyRectEncoding:
e = new CopyRectRectangle(rfb, framebuffer, rectangle);
break;
case VncHost.Encoding.RreEncoding:
e = new RreRectangle(rfb, framebuffer, pixels, rectangle);
break;
case VncHost.Encoding.CoRreEncoding:
e = new CoRreRectangle(rfb, framebuffer, pixels, rectangle);
break;
case VncHost.Encoding.HextileEncoding:
e = new HextileRectangle(rfb, framebuffer, pixels, rectangle);
break;
case VncHost.Encoding.ZrleEncoding:
e = new ZrleRectangle(rfb, framebuffer, pixels, rectangle);
break;
case VncHost.Encoding.ZlibEncoding:
e = new ZlibRectangle(rfb, framebuffer, pixels, rectangle);
break;
default:
// Sanity check
throw new Exception("Unsupported Encoding Format received: " + encoding + ".");
}
return e;
}
}
}