1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-12 18:23:04 +08:00

Crop screenshot image to scaling container.

This commit is contained in:
Nitrous 2024-01-25 09:27:10 +08:00
parent b272d34960
commit 30e335233d
No known key found for this signature in database
GPG Key ID: A5D82BAEC7C1D1F5

View File

@ -24,6 +24,7 @@ using osu.Game.Overlays;
using osu.Game.Overlays.Notifications; using osu.Game.Overlays.Notifications;
using SixLabors.ImageSharp; using SixLabors.ImageSharp;
using SixLabors.ImageSharp.Formats.Jpeg; using SixLabors.ImageSharp.Formats.Jpeg;
using SixLabors.ImageSharp.Processing;
namespace osu.Game.Graphics namespace osu.Game.Graphics
{ {
@ -52,6 +53,9 @@ namespace osu.Game.Graphics
private INotificationOverlay notificationOverlay { get; set; } private INotificationOverlay notificationOverlay { get; set; }
private Sample shutter; private Sample shutter;
private Bindable<float> sizeX;
private Bindable<float> sizeY;
private Bindable<ScalingMode> scalingMode;
[BackgroundDependencyLoader] [BackgroundDependencyLoader]
private void load(OsuConfigManager config, Storage storage, AudioManager audio) private void load(OsuConfigManager config, Storage storage, AudioManager audio)
@ -62,6 +66,10 @@ namespace osu.Game.Graphics
captureMenuCursor = config.GetBindable<bool>(OsuSetting.ScreenshotCaptureMenuCursor); captureMenuCursor = config.GetBindable<bool>(OsuSetting.ScreenshotCaptureMenuCursor);
shutter = audio.Samples.Get("UI/shutter"); shutter = audio.Samples.Get("UI/shutter");
sizeX = config.GetBindable<float>(OsuSetting.ScalingSizeX);
sizeY = config.GetBindable<float>(OsuSetting.ScalingSizeY);
scalingMode = config.GetBindable<ScalingMode>(OsuSetting.Scaling);
} }
public bool OnPressed(KeyBindingPressEvent<GlobalAction> e) public bool OnPressed(KeyBindingPressEvent<GlobalAction> e)
@ -119,6 +127,19 @@ namespace osu.Game.Graphics
using (var image = await host.TakeScreenshotAsync().ConfigureAwait(false)) using (var image = await host.TakeScreenshotAsync().ConfigureAwait(false))
{ {
if (scalingMode.Value == ScalingMode.Everything)
{
image.Mutate(m =>
{
var size = m.GetCurrentSize();
var rect = new Rectangle(Point.Empty, size);
int sx = (size.Width - (int)(size.Width * sizeX.Value)) / 2;
int sy = (size.Height - (int)(size.Height * sizeY.Value)) / 2;
rect.Inflate(-sx, -sy);
m.Crop(rect);
});
}
clipboard.SetImage(image); clipboard.SetImage(image);
(string filename, var stream) = getWritableStream(); (string filename, var stream) = getWritableStream();