mirror of
https://github.com/greenshot/greenshot
synced 2025-07-16 10:03:44 -07:00
Refactored the "thumbnail" preview code to ThumbnailForm.cs, this removes some complexity from the MainForm. Also fixed an Imgur issue, which I noticed as they currently have maintenance. And I added a missing key to the language-en-US.xml
git-svn-id: http://svn.code.sf.net/p/greenshot/code/trunk@1909 7dccd23d-a4a3-4e1f-8c07-b4c1b4018ab4
This commit is contained in:
parent
7918109284
commit
e274a08a1e
7 changed files with 143 additions and 100 deletions
|
@ -294,7 +294,7 @@ namespace Greenshot {
|
|||
private CopyData copyData = null;
|
||||
|
||||
// Thumbnail preview
|
||||
private FormWithoutActivation thumbnailForm = null;
|
||||
private ThumbnailForm thumbnailForm = null;
|
||||
private IntPtr thumbnailHandle = IntPtr.Zero;
|
||||
private Rectangle parentMenuBounds = Rectangle.Empty;
|
||||
// Make sure we have only one settings form
|
||||
|
@ -743,72 +743,17 @@ namespace Greenshot {
|
|||
private void ShowThumbnailOnEnter(object sender, EventArgs e) {
|
||||
ToolStripMenuItem captureWindowItem = sender as ToolStripMenuItem;
|
||||
WindowDetails window = captureWindowItem.Tag as WindowDetails;
|
||||
parentMenuBounds = captureWindowItem.GetCurrentParent().TopLevelControl.Bounds;
|
||||
if (thumbnailForm == null) {
|
||||
thumbnailForm = new FormWithoutActivation();
|
||||
thumbnailForm.ShowInTaskbar = false;
|
||||
thumbnailForm.FormBorderStyle = FormBorderStyle.None;
|
||||
thumbnailForm.TopMost = false;
|
||||
thumbnailForm.Enabled = false;
|
||||
if (conf.WindowCaptureMode == WindowCaptureMode.Auto || conf.WindowCaptureMode == WindowCaptureMode.Aero) {
|
||||
thumbnailForm.BackColor = Color.FromArgb(255, conf.DWMBackgroundColor.R, conf.DWMBackgroundColor.G, conf.DWMBackgroundColor.B);
|
||||
} else {
|
||||
thumbnailForm.BackColor = Color.White;
|
||||
}
|
||||
}
|
||||
if (thumbnailHandle != IntPtr.Zero) {
|
||||
DWM.DwmUnregisterThumbnail(thumbnailHandle);
|
||||
thumbnailHandle = IntPtr.Zero;
|
||||
}
|
||||
DWM.DwmRegisterThumbnail(thumbnailForm.Handle, window.Handle, out thumbnailHandle);
|
||||
if (thumbnailHandle != IntPtr.Zero) {
|
||||
Rectangle windowRectangle = window.WindowRectangle;
|
||||
int thumbnailHeight = 200;
|
||||
int thumbnailWidth = (int)(thumbnailHeight * ((float)windowRectangle.Width / (float)windowRectangle.Height));
|
||||
if (thumbnailWidth > parentMenuBounds.Width) {
|
||||
thumbnailWidth = parentMenuBounds.Width;
|
||||
thumbnailHeight = (int)(thumbnailWidth * ((float)windowRectangle.Height / (float)windowRectangle.Width));
|
||||
}
|
||||
thumbnailForm.Width = thumbnailWidth;
|
||||
thumbnailForm.Height = thumbnailHeight;
|
||||
// Prepare the displaying of the Thumbnail
|
||||
DWM_THUMBNAIL_PROPERTIES props = new DWM_THUMBNAIL_PROPERTIES();
|
||||
props.Opacity = (byte)255;
|
||||
props.Visible = true;
|
||||
props.SourceClientAreaOnly = false;
|
||||
props.Destination = new RECT(0, 0, thumbnailWidth, thumbnailHeight);
|
||||
DWM.DwmUpdateThumbnailProperties(thumbnailHandle, ref props);
|
||||
if (!thumbnailForm.Visible) {
|
||||
thumbnailForm.Show();
|
||||
}
|
||||
// Make sure it's on "top"!
|
||||
User32.SetWindowPos(thumbnailForm.Handle,captureWindowItem.GetCurrentParent().TopLevelControl.Handle, 0,0,0,0, WindowPos.SWP_NOMOVE | WindowPos.SWP_NOSIZE | WindowPos.SWP_NOACTIVATE);
|
||||
|
||||
// Align to menu
|
||||
Rectangle screenBounds = WindowCapture.GetScreenBounds();
|
||||
if (screenBounds.Contains(parentMenuBounds.Left, parentMenuBounds.Top - thumbnailHeight)) {
|
||||
thumbnailForm.Location = new Point(parentMenuBounds.Left + (parentMenuBounds.Width/2) - (thumbnailWidth/2), parentMenuBounds.Top - thumbnailHeight);
|
||||
} else {
|
||||
thumbnailForm.Location = new Point(parentMenuBounds.Left + (parentMenuBounds.Width/2) - (thumbnailWidth/2), parentMenuBounds.Bottom);
|
||||
}
|
||||
thumbnailForm = new ThumbnailForm();
|
||||
}
|
||||
thumbnailForm.ShowThumbnail(window, captureWindowItem.GetCurrentParent().TopLevelControl);
|
||||
}
|
||||
|
||||
private void HideThumbnailOnLeave(object sender, EventArgs e) {
|
||||
hideThumbnail();
|
||||
}
|
||||
|
||||
private void hideThumbnail() {
|
||||
if (thumbnailHandle != IntPtr.Zero) {
|
||||
DWM.DwmUnregisterThumbnail(thumbnailHandle);
|
||||
thumbnailHandle = IntPtr.Zero;
|
||||
thumbnailForm.Hide();
|
||||
}
|
||||
thumbnailForm.Hide();
|
||||
}
|
||||
|
||||
private void cleanupThumbnail() {
|
||||
hideThumbnail();
|
||||
|
||||
if (thumbnailForm != null) {
|
||||
thumbnailForm.Close();
|
||||
thumbnailForm = null;
|
||||
|
|
|
@ -161,9 +161,6 @@
|
|||
<Compile Include="Forms\CaptureForm.Designer.cs">
|
||||
<DependentUpon>CaptureForm.cs</DependentUpon>
|
||||
</Compile>
|
||||
<Compile Include="Forms\FormWithoutActivation.cs">
|
||||
<SubType>Form</SubType>
|
||||
</Compile>
|
||||
<Compile Include="Forms\ImageEditorForm.cs">
|
||||
<SubType>Form</SubType>
|
||||
</Compile>
|
||||
|
|
|
@ -5,19 +5,19 @@
|
|||
<resource name="about_donations">If you like Greenshot, you are welcome to support us:</resource>
|
||||
<resource name="about_host">Greenshot is hosted by sourceforge.net at</resource>
|
||||
<resource name="about_icons">Icons from Yusuke Kamiyamane's Fugue icon set (Creative Commons Attribution 3.0 license)</resource>
|
||||
<resource name="about_license">Copyright (C) 2007-2012 Thomas Braun, Jens Klingen, Robin Krom
|
||||
Greenshot comes with ABSOLUTELY NO WARRANTY. This is free software, and you are welcome to redistribute it under certain conditions.
|
||||
<resource name="about_license">Copyright (C) 2007-2012 Thomas Braun, Jens Klingen, Robin Krom
|
||||
Greenshot comes with ABSOLUTELY NO WARRANTY. This is free software, and you are welcome to redistribute it under certain conditions.
|
||||
Details about the GNU General Public License:</resource>
|
||||
<resource name="about_title">About Greenshot</resource>
|
||||
<resource name="about_translation" />
|
||||
<resource name="application_title">Greenshot - the revolutionary screenshot utility</resource>
|
||||
<resource name="bugreport_cancel">Close</resource>
|
||||
<resource name="bugreport_info">Sorry, an unexpected error occured.
|
||||
|
||||
The good news is: you can help us getting rid of it by filing a bug report.
|
||||
Please visit the URL below, create a new bug report and paste the contents from the text area into the description.
|
||||
|
||||
Please add a meaningful summary and enclose any information you consider to be helpful for reproducing the issue.
|
||||
<resource name="bugreport_info">Sorry, an unexpected error occured.
|
||||
|
||||
The good news is: you can help us getting rid of it by filing a bug report.
|
||||
Please visit the URL below, create a new bug report and paste the contents from the text area into the description.
|
||||
|
||||
Please add a meaningful summary and enclose any information you consider to be helpful for reproducing the issue.
|
||||
Also, we would highly appreciate if you checked whether a tracker item already exists for this bug. (You can use the search to find those quickly.) Thank you :)</resource>
|
||||
<resource name="bugreport_title">Error</resource>
|
||||
<resource name="CANCEL">Cancel</resource>
|
||||
|
@ -51,6 +51,7 @@ Also, we would highly appreciate if you checked whether a tracker item already e
|
|||
<resource name="contextmenu_openrecentcapture">Open last capture location</resource>
|
||||
<resource name="contextmenu_quicksettings">Quick preferences</resource>
|
||||
<resource name="contextmenu_settings">Preferences...</resource>
|
||||
<resource name="destination_exportfailed">Error while exporting to {0}. Please try again.</resource>
|
||||
<resource name="editor_arrange">Arrange</resource>
|
||||
<resource name="editor_arrowheads">Arrow heads</resource>
|
||||
<resource name="editor_arrowheads_both">Both</resource>
|
||||
|
@ -137,7 +138,7 @@ Also, we would highly appreciate if you checked whether a tracker item already e
|
|||
<resource name="EmailFormat.OUTLOOK_TXT">Outlook with text</resource>
|
||||
<resource name="error">Error</resource>
|
||||
<resource name="error_multipleinstances">An instance of Greenshot is already running.</resource>
|
||||
<resource name="error_nowriteaccess">Cannot save file to {0}.
|
||||
<resource name="error_nowriteaccess">Cannot save file to {0}.
|
||||
Please check write accessibility of the selected storage location.</resource>
|
||||
<resource name="error_openfile">The file "{0}" could not be opened.</resource>
|
||||
<resource name="error_openlink">Could not open link '{0}'.</resource>
|
||||
|
@ -201,22 +202,22 @@ Please check write accessibility of the selected storage location.</resource>
|
|||
<resource name="settings_jpegquality">JPEG quality</resource>
|
||||
<resource name="settings_jpegsettings">Quality settings</resource>
|
||||
<resource name="settings_language">Language</resource>
|
||||
<resource name="settings_message_filenamepattern">The following placeholders will be replaced automatically in the pattern defined:
|
||||
${YYYY} year, 4 digits
|
||||
${MM} month, 2 digits
|
||||
${DD} day, 2 digits
|
||||
${hh} hour, 2 digits
|
||||
${mm} minute, 2 digits
|
||||
${ss} second, 2 digits
|
||||
${NUM} incrementing number, 6 digits
|
||||
${title} Window title
|
||||
${user} Windows user
|
||||
${domain} Windows domain
|
||||
${hostname} PC name
|
||||
|
||||
You can also have Greenshot create directories dynamically, simply use the backslash symbol (\) to separate folders and filename.
|
||||
Example: the pattern ${YYYY}-${MM}-${DD}\${hh}-${mm}-${ss}
|
||||
will generate a folder for the current day in your default storage location, e.g. 2008-06-29, the contained screenshot file's name will be based on the current
|
||||
<resource name="settings_message_filenamepattern">The following placeholders will be replaced automatically in the pattern defined:
|
||||
${YYYY} year, 4 digits
|
||||
${MM} month, 2 digits
|
||||
${DD} day, 2 digits
|
||||
${hh} hour, 2 digits
|
||||
${mm} minute, 2 digits
|
||||
${ss} second, 2 digits
|
||||
${NUM} incrementing number, 6 digits
|
||||
${title} Window title
|
||||
${user} Windows user
|
||||
${domain} Windows domain
|
||||
${hostname} PC name
|
||||
|
||||
You can also have Greenshot create directories dynamically, simply use the backslash symbol (\) to separate folders and filename.
|
||||
Example: the pattern ${YYYY}-${MM}-${DD}\${hh}-${mm}-${ss}
|
||||
will generate a folder for the current day in your default storage location, e.g. 2008-06-29, the contained screenshot file's name will be based on the current
|
||||
time, e.g. 11_58_32 (plus extension defined in the settings)</resource>
|
||||
<resource name="settings_network">Network and updates</resource>
|
||||
<resource name="settings_output">Output</resource>
|
||||
|
@ -246,8 +247,8 @@ time, e.g. 11_58_32 (plus extension defined in the settings)</resource>
|
|||
<resource name="update_found">A newer version of Greenshot is available! Do you want to download Greenshot {0}?</resource>
|
||||
<resource name="wait_ie_capture">Please wait while the page in Internet Explorer is captured...</resource>
|
||||
<resource name="warning">Warning</resource>
|
||||
<resource name="warning_hotkeys">The hotkey(s) "{0}" could not be registered. This problem is probably caused by another tool claiming usage of the same hotkey(s)! You could either change your hotkey settings or deactivate/change the software making use of the hotkey(s).
|
||||
|
||||
<resource name="warning_hotkeys">The hotkey(s) "{0}" could not be registered. This problem is probably caused by another tool claiming usage of the same hotkey(s)! You could either change your hotkey settings or deactivate/change the software making use of the hotkey(s).
|
||||
|
||||
All Greenshot features still work directly from the tray icon context menu without hotkeys.</resource>
|
||||
<resource name="WindowCaptureMode.Aero">Use custom color</resource>
|
||||
<resource name="WindowCaptureMode.AeroTransparent">Preserve transparency</resource>
|
||||
|
|
|
@ -156,8 +156,12 @@ namespace GreenshotImgurPlugin {
|
|||
}
|
||||
|
||||
public static void RetrieveImgurThumbnail(ImgurInfo imgurInfo) {
|
||||
LOG.InfoFormat("Retrieving Imgur image for {0} with url {1}", imgurInfo.Hash, imgurInfo);
|
||||
HttpWebRequest webRequest = (HttpWebRequest)NetworkHelper.CreateWebRequest(imgurInfo.SmallSquare);
|
||||
if (imgurInfo.SmallSquare == null) {
|
||||
LOG.Warn("Imgur URL was null, not retrieving thumbnail.");
|
||||
return;
|
||||
}
|
||||
LOG.InfoFormat("Retrieving Imgur image for {0} with url {1}", imgurInfo.Hash, imgurInfo);
|
||||
HttpWebRequest webRequest = (HttpWebRequest)NetworkHelper.CreateWebRequest(imgurInfo.SmallSquare);
|
||||
webRequest.Method = "GET";
|
||||
webRequest.ServicePoint.Expect100Continue = false;
|
||||
|
||||
|
|
|
@ -21,13 +21,13 @@
|
|||
using System;
|
||||
using System.Windows.Forms;
|
||||
|
||||
namespace Greenshot.Forms {
|
||||
/// <summary>
|
||||
/// FormWithoutActivation is exactly like a normal form, but doesn't activate (steal focus)
|
||||
/// </summary>
|
||||
public class FormWithoutActivation : Form {
|
||||
protected override bool ShowWithoutActivation {
|
||||
get { return true; }
|
||||
}
|
||||
}
|
||||
namespace GreenshotPlugin.Controls {
|
||||
/// <summary>
|
||||
/// FormWithoutActivation is exactly like a normal form, but doesn't activate (steal focus)
|
||||
/// </summary>
|
||||
public class FormWithoutActivation : Form {
|
||||
protected override bool ShowWithoutActivation {
|
||||
get { return true; }
|
||||
}
|
||||
}
|
||||
}
|
90
GreenshotPlugin/Controls/ThumbnailForm.cs
Normal file
90
GreenshotPlugin/Controls/ThumbnailForm.cs
Normal file
|
@ -0,0 +1,90 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Text;
|
||||
using System.Windows.Forms;
|
||||
using GreenshotPlugin.Core;
|
||||
using Greenshot.IniFile;
|
||||
using System.Drawing;
|
||||
using GreenshotPlugin.UnmanagedHelpers;
|
||||
|
||||
namespace GreenshotPlugin.Controls {
|
||||
public class ThumbnailForm : FormWithoutActivation {
|
||||
private static CoreConfiguration conf = IniConfig.GetIniSection<CoreConfiguration>();
|
||||
|
||||
private IntPtr thumbnailHandle = IntPtr.Zero;
|
||||
private Rectangle parentMenuBounds = Rectangle.Empty;
|
||||
|
||||
public ThumbnailForm() {
|
||||
ShowInTaskbar = false;
|
||||
FormBorderStyle = FormBorderStyle.None;
|
||||
TopMost = false;
|
||||
Enabled = false;
|
||||
if (conf.WindowCaptureMode == WindowCaptureMode.Auto || conf.WindowCaptureMode == WindowCaptureMode.Aero) {
|
||||
BackColor = Color.FromArgb(255, conf.DWMBackgroundColor.R, conf.DWMBackgroundColor.G, conf.DWMBackgroundColor.B);
|
||||
} else {
|
||||
BackColor = Color.White;
|
||||
}
|
||||
|
||||
// cleanup at close
|
||||
this.FormClosing += delegate {
|
||||
UnregisterThumbnail();
|
||||
};
|
||||
}
|
||||
|
||||
public new void Hide() {
|
||||
UnregisterThumbnail();
|
||||
base.Hide();
|
||||
}
|
||||
|
||||
private void UnregisterThumbnail() {
|
||||
if (thumbnailHandle != IntPtr.Zero) {
|
||||
DWM.DwmUnregisterThumbnail(thumbnailHandle);
|
||||
thumbnailHandle = IntPtr.Zero;
|
||||
}
|
||||
}
|
||||
|
||||
public void ShowThumbnail(WindowDetails window, Control parentControl) {
|
||||
UnregisterThumbnail();
|
||||
|
||||
DWM.DwmRegisterThumbnail(Handle, window.Handle, out thumbnailHandle);
|
||||
if (thumbnailHandle != IntPtr.Zero) {
|
||||
Rectangle windowRectangle = window.WindowRectangle;
|
||||
int thumbnailHeight = 200;
|
||||
int thumbnailWidth = (int)(thumbnailHeight * ((float)windowRectangle.Width / (float)windowRectangle.Height));
|
||||
if (parentControl != null && thumbnailWidth > parentControl.Width) {
|
||||
thumbnailWidth = parentControl.Width;
|
||||
thumbnailHeight = (int)(thumbnailWidth * ((float)windowRectangle.Height / (float)windowRectangle.Width));
|
||||
}
|
||||
Width = thumbnailWidth;
|
||||
Height = thumbnailHeight;
|
||||
// Prepare the displaying of the Thumbnail
|
||||
DWM_THUMBNAIL_PROPERTIES props = new DWM_THUMBNAIL_PROPERTIES();
|
||||
props.Opacity = (byte)255;
|
||||
props.Visible = true;
|
||||
props.SourceClientAreaOnly = false;
|
||||
props.Destination = new RECT(0, 0, thumbnailWidth, thumbnailHeight);
|
||||
DWM.DwmUpdateThumbnailProperties(thumbnailHandle, ref props);
|
||||
if (parentControl != null) {
|
||||
AlignToControl(parentControl);
|
||||
}
|
||||
|
||||
if (!Visible) {
|
||||
Show();
|
||||
}
|
||||
// Make sure it's on "top"!
|
||||
if (parentControl != null) {
|
||||
User32.SetWindowPos(Handle, parentControl.Handle, 0, 0, 0, 0, WindowPos.SWP_NOMOVE | WindowPos.SWP_NOSIZE | WindowPos.SWP_NOACTIVATE);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void AlignToControl(Control alignTo) {
|
||||
Rectangle screenBounds = WindowCapture.GetScreenBounds();
|
||||
if (screenBounds.Contains(alignTo.Left, alignTo.Top - Height)) {
|
||||
Location = new Point(alignTo.Left + (alignTo.Width / 2) - (Width / 2), alignTo.Top - Height);
|
||||
} else {
|
||||
Location = new Point(alignTo.Left + (alignTo.Width / 2) - (Width / 2), alignTo.Bottom);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -175,6 +175,9 @@
|
|||
<Compile Include="..\GreenshotInterop\OfficeInterop\WordInterop.cs">
|
||||
<Link>Interop\WordInterop.cs</Link>
|
||||
</Compile>
|
||||
<Compile Include="Controls\FormWithoutActivation.cs">
|
||||
<SubType>Form</SubType>
|
||||
</Compile>
|
||||
<Compile Include="Controls\GreenshotButton.cs">
|
||||
<SubType>Component</SubType>
|
||||
</Compile>
|
||||
|
@ -223,6 +226,9 @@
|
|||
<Compile Include="Controls\GreenshotToolDropDownButton.cs">
|
||||
<SubType>Component</SubType>
|
||||
</Compile>
|
||||
<Compile Include="Controls\ThumbnailForm.cs">
|
||||
<SubType>Form</SubType>
|
||||
</Compile>
|
||||
<Compile Include="Core\AbstractDestination.cs" />
|
||||
<Compile Include="Core\AbstractProcessor.cs" />
|
||||
<Compile Include="Core\AccessibleHelper.cs" />
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue