mirror of
https://github.com/ShareX/ShareX.git
synced 2024-10-04 12:14:45 +13:00
Rectangle annotate improvements
This commit is contained in:
parent
5eb0ee3e4a
commit
39d0a70bd5
1 changed files with 121 additions and 55 deletions
|
@ -81,13 +81,42 @@ public Point PreviousMousePosition0Based
|
||||||
|
|
||||||
public bool ShowRectangleInfo { get; set; }
|
public bool ShowRectangleInfo { get; set; }
|
||||||
|
|
||||||
|
private bool cursorShown = true;
|
||||||
|
|
||||||
|
public bool CursorShown
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return cursorShown;
|
||||||
|
}
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (cursorShown == value)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (value)
|
||||||
|
{
|
||||||
|
Cursor.Show();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Cursor.Hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
cursorShown = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private Timer timer;
|
private Timer timer;
|
||||||
private Image backgroundImage;
|
private Image backgroundImage;
|
||||||
private Pen borderDotPen, borderDotPen2;
|
private Pen borderDotPen, borderDotPen2;
|
||||||
private Point positionOnClick;
|
private Point positionOnClick;
|
||||||
private bool isMouseDown, isDrawingMode;
|
private bool isMouseDown, isCtrlDown;
|
||||||
private Stopwatch penTimer;
|
private Stopwatch penTimer;
|
||||||
private Cursor crosshairCursor;
|
private int drawingPenSize = 7;
|
||||||
|
private Color drawingPenColor = Color.FromArgb(255, 0, 0);
|
||||||
|
|
||||||
public RectangleAnnotate()
|
public RectangleAnnotate()
|
||||||
{
|
{
|
||||||
|
@ -102,11 +131,9 @@ public RectangleAnnotate()
|
||||||
|
|
||||||
using (MemoryStream cursorStream = new MemoryStream(Resources.Crosshair))
|
using (MemoryStream cursorStream = new MemoryStream(Resources.Crosshair))
|
||||||
{
|
{
|
||||||
crosshairCursor = new Cursor(cursorStream);
|
Cursor = new Cursor(cursorStream);
|
||||||
}
|
}
|
||||||
|
|
||||||
Cursor = crosshairCursor;
|
|
||||||
|
|
||||||
timer = new Timer { Interval = 10 };
|
timer = new Timer { Interval = 10 };
|
||||||
timer.Tick += timer_Tick;
|
timer.Tick += timer_Tick;
|
||||||
timer.Start();
|
timer.Start();
|
||||||
|
@ -125,7 +152,6 @@ protected override void Dispose(bool disposing)
|
||||||
if (backgroundImage != null) backgroundImage.Dispose();
|
if (backgroundImage != null) backgroundImage.Dispose();
|
||||||
if (borderDotPen != null) borderDotPen.Dispose();
|
if (borderDotPen != null) borderDotPen.Dispose();
|
||||||
if (borderDotPen2 != null) borderDotPen2.Dispose();
|
if (borderDotPen2 != null) borderDotPen2.Dispose();
|
||||||
if (crosshairCursor != null) crosshairCursor.Dispose();
|
|
||||||
|
|
||||||
base.Dispose(disposing);
|
base.Dispose(disposing);
|
||||||
}
|
}
|
||||||
|
@ -142,43 +168,61 @@ private void InitializeComponent()
|
||||||
Text = "ShareX - Rectangle Capture Annotate";
|
Text = "ShareX - Rectangle Capture Annotate";
|
||||||
ShowInTaskbar = false;
|
ShowInTaskbar = false;
|
||||||
TopMost = true;
|
TopMost = true;
|
||||||
Shown += RectangleLight_Shown;
|
|
||||||
KeyUp += RectangleLight_KeyUp;
|
Shown += RectangleAnnotate_Shown;
|
||||||
MouseDown += RectangleLight_MouseDown;
|
MouseDown += RectangleAnnotate_MouseDown;
|
||||||
MouseUp += RectangleLight_MouseUp;
|
MouseUp += RectangleAnnotate_MouseUp;
|
||||||
|
MouseWheel += RectangleAnnotate_MouseWheel;
|
||||||
|
KeyDown += RectangleAnnotate_KeyDown;
|
||||||
|
KeyUp += RectangleAnnotate_KeyUp;
|
||||||
|
FormClosing += RectangleAnnotate_FormClosing;
|
||||||
|
|
||||||
ResumeLayout(false);
|
ResumeLayout(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void RectangleLight_Shown(object sender, EventArgs e)
|
private void RectangleAnnotate_Shown(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
this.ShowActivate();
|
this.ShowActivate();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void RectangleLight_KeyUp(object sender, KeyEventArgs e)
|
private void RectangleAnnotate_FormClosing(object sender, FormClosingEventArgs e)
|
||||||
|
{
|
||||||
|
CursorShown = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void RectangleAnnotate_KeyDown(object sender, KeyEventArgs e)
|
||||||
|
{
|
||||||
|
if (e.KeyCode == Keys.ControlKey)
|
||||||
|
{
|
||||||
|
isCtrlDown = true;
|
||||||
|
CursorShown = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void RectangleAnnotate_KeyUp(object sender, KeyEventArgs e)
|
||||||
{
|
{
|
||||||
if (e.KeyCode == Keys.Escape)
|
if (e.KeyCode == Keys.Escape)
|
||||||
{
|
{
|
||||||
Close();
|
Close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (e.KeyCode == Keys.ControlKey)
|
||||||
|
{
|
||||||
|
isCtrlDown = false;
|
||||||
|
CursorShown = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void RectangleLight_MouseDown(object sender, MouseEventArgs e)
|
private void RectangleAnnotate_MouseDown(object sender, MouseEventArgs e)
|
||||||
{
|
{
|
||||||
if (e.Button == MouseButtons.Left)
|
if (e.Button == MouseButtons.Left)
|
||||||
{
|
{
|
||||||
positionOnClick = CaptureHelpers.GetCursorPosition();
|
positionOnClick = CaptureHelpers.GetCursorPosition();
|
||||||
isMouseDown = true;
|
isMouseDown = true;
|
||||||
|
|
||||||
if (Control.ModifierKeys == Keys.Control)
|
|
||||||
{
|
|
||||||
isDrawingMode = true;
|
|
||||||
Cursor = Cursors.Cross;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (isMouseDown)
|
else if (isMouseDown)
|
||||||
{
|
{
|
||||||
isMouseDown = false;
|
isMouseDown = false;
|
||||||
isDrawingMode = false;
|
|
||||||
Refresh();
|
Refresh();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -187,26 +231,41 @@ private void RectangleLight_MouseDown(object sender, MouseEventArgs e)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void RectangleLight_MouseUp(object sender, MouseEventArgs e)
|
private void RectangleAnnotate_MouseUp(object sender, MouseEventArgs e)
|
||||||
{
|
{
|
||||||
if (isDrawingMode)
|
if (isMouseDown && e.Button == MouseButtons.Left)
|
||||||
{
|
{
|
||||||
isMouseDown = false;
|
if (isCtrlDown)
|
||||||
isDrawingMode = false;
|
|
||||||
Cursor = crosshairCursor;
|
|
||||||
}
|
|
||||||
else if (isMouseDown && e.Button == MouseButtons.Left)
|
|
||||||
{
|
|
||||||
if (SelectionRectangle0Based.Width > 0 && SelectionRectangle0Based.Height > 0)
|
|
||||||
{
|
{
|
||||||
LastSelectionRectangle0Based = SelectionRectangle0Based;
|
isMouseDown = false;
|
||||||
DialogResult = DialogResult.OK;
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (SelectionRectangle0Based.Width > 0 && SelectionRectangle0Based.Height > 0)
|
||||||
|
{
|
||||||
|
LastSelectionRectangle0Based = SelectionRectangle0Based;
|
||||||
|
DialogResult = DialogResult.OK;
|
||||||
|
}
|
||||||
|
|
||||||
Close();
|
Close();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void RectangleAnnotate_MouseWheel(object sender, MouseEventArgs e)
|
||||||
|
{
|
||||||
|
if (e.Delta > 0)
|
||||||
|
{
|
||||||
|
drawingPenSize++;
|
||||||
|
}
|
||||||
|
else if (e.Delta < 0)
|
||||||
|
{
|
||||||
|
drawingPenSize--;
|
||||||
|
}
|
||||||
|
|
||||||
|
drawingPenSize = drawingPenSize.Between(1, 100);
|
||||||
|
}
|
||||||
|
|
||||||
public Image GetAreaImage()
|
public Image GetAreaImage()
|
||||||
{
|
{
|
||||||
Rectangle rect = SelectionRectangle0Based;
|
Rectangle rect = SelectionRectangle0Based;
|
||||||
|
@ -243,39 +302,46 @@ protected override void OnPaint(PaintEventArgs e)
|
||||||
g.InterpolationMode = InterpolationMode.NearestNeighbor;
|
g.InterpolationMode = InterpolationMode.NearestNeighbor;
|
||||||
g.SmoothingMode = SmoothingMode.HighSpeed;
|
g.SmoothingMode = SmoothingMode.HighSpeed;
|
||||||
|
|
||||||
if (isDrawingMode)
|
if (isCtrlDown && isMouseDown)
|
||||||
{
|
{
|
||||||
using (Graphics gBackgroundImage = Graphics.FromImage(backgroundImage))
|
using (Graphics gBackgroundImage = Graphics.FromImage(backgroundImage))
|
||||||
using (Pen penDrawing = new Pen(Color.FromArgb(0, 255, 0), 5) { StartCap = LineCap.Round, EndCap = LineCap.Round })
|
using (Pen penDrawing = new Pen(drawingPenColor, drawingPenSize) { StartCap = LineCap.Round, EndCap = LineCap.Round })
|
||||||
{
|
{
|
||||||
gBackgroundImage.DrawLine(penDrawing, PreviousMousePosition0Based, CurrentMousePosition0Based);
|
gBackgroundImage.DrawLine(penDrawing, PreviousMousePosition0Based, CurrentMousePosition0Based);
|
||||||
}
|
}
|
||||||
|
|
||||||
g.DrawImage(backgroundImage, ScreenRectangle0Based);
|
|
||||||
}
|
}
|
||||||
else
|
|
||||||
|
g.DrawImage(backgroundImage, ScreenRectangle0Based);
|
||||||
|
|
||||||
|
if (isCtrlDown)
|
||||||
{
|
{
|
||||||
g.DrawImage(backgroundImage, ScreenRectangle0Based);
|
using (Pen penDrawing = new Pen(drawingPenColor, drawingPenSize) { StartCap = LineCap.Round, EndCap = LineCap.Round })
|
||||||
|
using (Brush brushDrawing = new SolidBrush(drawingPenColor))
|
||||||
if (isMouseDown)
|
|
||||||
{
|
{
|
||||||
if (ShowRectangleInfo)
|
Rectangle rectCursor = new Rectangle(CurrentMousePosition0Based.X - drawingPenSize / 2, CurrentMousePosition0Based.Y - drawingPenSize / 2, drawingPenSize, drawingPenSize);
|
||||||
{
|
g.FillEllipse(brushDrawing, rectCursor);
|
||||||
int offset = 10;
|
g.DrawEllipse(Pens.Black, rectCursor);
|
||||||
Point position = new Point(CurrentMousePosition0Based.X + offset, CurrentMousePosition0Based.Y + offset);
|
|
||||||
|
|
||||||
using (Font font = new Font("Arial", 17, FontStyle.Bold))
|
|
||||||
{
|
|
||||||
ImageHelpers.DrawTextWithOutline(g, string.Format("{0}, {1}\r\n{2} x {3}", SelectionRectangle.X, SelectionRectangle.Y,
|
|
||||||
SelectionRectangle.Width, SelectionRectangle.Height), position, font, Color.White, Color.Black, 3);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
g.DrawRectangleProper(borderDotPen, SelectionRectangle0Based);
|
|
||||||
borderDotPen2.DashOffset = (int)(penTimer.Elapsed.TotalMilliseconds / 100) % 10;
|
|
||||||
g.DrawRectangleProper(borderDotPen2, SelectionRectangle0Based);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isMouseDown && !isCtrlDown)
|
||||||
|
{
|
||||||
|
if (ShowRectangleInfo)
|
||||||
|
{
|
||||||
|
int offset = 10;
|
||||||
|
Point position = new Point(CurrentMousePosition0Based.X + offset, CurrentMousePosition0Based.Y + offset);
|
||||||
|
|
||||||
|
using (Font font = new Font("Arial", 17, FontStyle.Bold))
|
||||||
|
{
|
||||||
|
ImageHelpers.DrawTextWithOutline(g, string.Format("{0}, {1}\r\n{2} x {3}", SelectionRectangle.X, SelectionRectangle.Y,
|
||||||
|
SelectionRectangle.Width, SelectionRectangle.Height), position, font, Color.White, Color.Black, 3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
g.DrawRectangleProper(borderDotPen, SelectionRectangle0Based);
|
||||||
|
borderDotPen2.DashOffset = (int)(penTimer.Elapsed.TotalMilliseconds / 100) % 10;
|
||||||
|
g.DrawRectangleProper(borderDotPen2, SelectionRectangle0Based);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue