mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 18:52:55 +08:00
Merge branch 'master' into user-id-in-replays
This commit is contained in:
commit
5a9a786199
@ -6,6 +6,7 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text.RegularExpressions;
|
using System.Text.RegularExpressions;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
@ -21,6 +22,8 @@ using osu.Game.Utils;
|
|||||||
|
|
||||||
namespace osu.Game.Beatmaps.Drawables
|
namespace osu.Game.Beatmaps.Drawables
|
||||||
{
|
{
|
||||||
|
[SuppressMessage("ReSharper", "StringLiteralTypo")]
|
||||||
|
[SuppressMessage("ReSharper", "CommentTypo")]
|
||||||
public partial class BundledBeatmapDownloader : CompositeDrawable
|
public partial class BundledBeatmapDownloader : CompositeDrawable
|
||||||
{
|
{
|
||||||
private readonly bool shouldPostNotifications;
|
private readonly bool shouldPostNotifications;
|
||||||
@ -50,7 +53,7 @@ namespace osu.Game.Beatmaps.Drawables
|
|||||||
{
|
{
|
||||||
queueDownloads(always_bundled_beatmaps);
|
queueDownloads(always_bundled_beatmaps);
|
||||||
|
|
||||||
queueDownloads(bundled_osu, 8);
|
queueDownloads(bundled_osu, 6);
|
||||||
queueDownloads(bundled_taiko, 3);
|
queueDownloads(bundled_taiko, 3);
|
||||||
queueDownloads(bundled_catch, 3);
|
queueDownloads(bundled_catch, 3);
|
||||||
queueDownloads(bundled_mania, 3);
|
queueDownloads(bundled_mania, 3);
|
||||||
@ -128,6 +131,26 @@ namespace osu.Game.Beatmaps.Drawables
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* criteria for bundled maps (managed by pishifat)
|
||||||
|
*
|
||||||
|
* auto:
|
||||||
|
* - licensed song
|
||||||
|
* - includes ENHI diffs
|
||||||
|
* - between 60s and 240s
|
||||||
|
*
|
||||||
|
* manual:
|
||||||
|
* - bg is explicitly permitted as okay to use. lots of artists say some variation of "it's ok for personal use/non-commercial use/with credit"
|
||||||
|
* (which is prob fine when maps are presented as user-generated content), but for a new osu! player, it's easy to assume bundled maps are
|
||||||
|
* commercial content like other rhythm games, so it's best to be cautious about using not-explicitly-permitted artwork.
|
||||||
|
*
|
||||||
|
* - no ai/thirst bgs
|
||||||
|
* - no controversial/explicit song content or titles
|
||||||
|
* - no repeating bundled songs (within each mode)
|
||||||
|
* - no songs that are relatively low production value
|
||||||
|
* - no songs with limited accessibility (annoying high pitch vocals, noise rock, etc)
|
||||||
|
*/
|
||||||
|
|
||||||
private const string tutorial_filename = "1011011 nekodex - new beginnings.osz";
|
private const string tutorial_filename = "1011011 nekodex - new beginnings.osz";
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -135,215 +158,312 @@ namespace osu.Game.Beatmaps.Drawables
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
private static readonly string[] always_bundled_beatmaps =
|
private static readonly string[] always_bundled_beatmaps =
|
||||||
{
|
{
|
||||||
// This thing is 40mb, I'm not sure we want it here...
|
// winner of https://osu.ppy.sh/home/news/2013-09-06-osu-monthly-beatmapping-contest-1
|
||||||
|
@"123593 Rostik - Liquid (Paul Rosenthal Remix).osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2013-10-28-monthly-beatmapping-contest-2-submissions-open
|
||||||
|
@"140662 cYsmix feat. Emmy - Tear Rain.osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2013-12-15-monthly-beatmapping-contest-3-submissions-open
|
||||||
|
@"151878 Chasers - Lost.osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2014-02-14-monthly-beatmapping-contest-4-submissions-now
|
||||||
|
@"163112 Kuba Oms - My Love.osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2014-05-07-monthly-beatmapping-contest-5-submissions-now
|
||||||
|
@"190390 Rameses B - Flaklypa.osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2014-09-24-monthly-beatmapping-contest-7
|
||||||
|
@"241526 Soleily - Renatus.osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2015-02-11-monthly-beatmapping-contest-8
|
||||||
|
@"299224 raja - the light.osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2015-04-13-monthly-beatmapping-contest-9-taiko-only
|
||||||
|
@"319473 Furries in a Blender - Storm World.osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2015-06-15-monthly-beatmapping-contest-10-ctb-only
|
||||||
|
@"342751 Hylian Lemon - Foresight Is for Losers.osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2015-08-22-monthly-beatmapping-contest-11-mania-only
|
||||||
|
@"385056 Toni Leys - Dragon Valley (Toni Leys Remix feat. Esteban Bellucci).osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2016-03-04-beatmapping-contest-12-osu
|
||||||
|
@"456054 IAHN - Candy Luv (Short Ver.).osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2020-11-30-a-labour-of-love
|
||||||
|
// (this thing is 40mb, I'm not sure if we want it here...)
|
||||||
@"1388906 Raphlesia & BilliumMoto - My Love.osz",
|
@"1388906 Raphlesia & BilliumMoto - My Love.osz",
|
||||||
// Winner of Triangles mapping competition: https://osu.ppy.sh/home/news/2022-10-06-results-triangles
|
// winner of https://osu.ppy.sh/home/news/2022-05-31-triangles
|
||||||
@"1841885 cYsmix - triangles.osz",
|
@"1841885 cYsmix - triangles.osz",
|
||||||
|
// winner of https://osu.ppy.sh/home/news/2023-02-01-twin-trials-contest-beatmapping-phase
|
||||||
|
@"1971987 James Landino - Aresene's Bazaar.osz",
|
||||||
};
|
};
|
||||||
|
|
||||||
private static readonly string[] bundled_osu =
|
private static readonly string[] bundled_osu =
|
||||||
{
|
{
|
||||||
"682286 Yuyoyuppe - Emerald Galaxy.osz",
|
@"682286 Yuyoyuppe - Emerald Galaxy.osz",
|
||||||
"682287 baker - For a Dead Girl+.osz",
|
@"682287 baker - For a Dead Girl+.osz",
|
||||||
"682289 Hige Driver - I Wanna Feel Your Love (feat. shully).osz",
|
@"682595 baker - Kimi ga Kimi ga -vocanico remix-.osz",
|
||||||
"682290 Hige Driver - Miracle Sugite Yabai (feat. shully).osz",
|
@"1048705 Thaehan - Never Give Up.osz",
|
||||||
"682416 Hige Driver - Palette.osz",
|
@"1050185 Carpool Tunnel - Hooked Again.osz",
|
||||||
"682595 baker - Kimi ga Kimi ga -vocanico remix-.osz",
|
@"1052846 Carpool Tunnel - Impressions.osz",
|
||||||
"716211 yuki. - Spring Signal.osz",
|
@"1062477 Ricky Montgomery - Line Without a Hook.osz",
|
||||||
"716213 dark cat - BUBBLE TEA (feat. juu & cinders).osz",
|
@"1081119 Celldweller - Pulsar.osz",
|
||||||
"716215 LukHash - CLONED.osz",
|
@"1086289 Frums - 24eeev0-$.osz",
|
||||||
"716219 IAHN - Snowdrop.osz",
|
@"1133317 PUP - Free At Last.osz",
|
||||||
"716249 *namirin - Senaka Awase no Kuukyo (with Kakichoco).osz",
|
@"1171188 PUP - Full Blown Meltdown.osz",
|
||||||
"716390 sakuraburst - SHA.osz",
|
@"1177043 PUP - My Life Is Over And I Couldn't Be Happier.osz",
|
||||||
"716441 Fractal Dreamers - Paradigm Shift.osz",
|
@"1250387 Circle of Dust - Humanarchy (Cut Ver.).osz",
|
||||||
"729808 Thaehan - Leprechaun.osz",
|
@"1255411 Wisp X - Somewhere I'd Rather Be.osz",
|
||||||
"751771 Cranky - Hanaarashi.osz",
|
@"1320298 nekodex - Little Drummer Girl.osz",
|
||||||
"751772 Cranky - Ran.osz",
|
@"1323877 Masahiro ""Godspeed"" Aoki - Blaze.osz",
|
||||||
"751773 Cranky - Feline, the White....osz",
|
@"1342280 Minagu feat. Aitsuki Nakuru - Theater Endroll.osz",
|
||||||
"751774 Function Phantom - Variable.osz",
|
@"1356447 SECONDWALL - Boku wa Boku de shika Nakute.osz",
|
||||||
"751779 Rin - Daishibyo set 14 ~ Sado no Futatsuiwa.osz",
|
@"1368054 SECONDWALL - Shooting Star.osz",
|
||||||
"751782 Fractal Dreamers - Fata Morgana.osz",
|
@"1398580 La priere - Senjou no Utahime.osz",
|
||||||
"751785 Cranky - Chandelier - King.osz",
|
@"1403962 m108 - Sunflower.osz",
|
||||||
"751846 Fractal Dreamers - Celestial Horizon.osz",
|
@"1405913 fiend - FEVER DREAM (feat. yzzyx).osz",
|
||||||
"751866 Rin - Moriya set 08 ReEdit ~ Youkai no Yama.osz",
|
@"1409184 Omoi - Hey William (New Translation).osz",
|
||||||
"751894 Fractal Dreamers - Blue Haven.osz",
|
@"1413418 URBANGARDE - KAMING OUT (Cut Ver.).osz",
|
||||||
"751896 Cranky - Rave 2 Rave.osz",
|
@"1417793 P4koo (NONE) - Sogaikan Utopia.osz",
|
||||||
"751932 Cranky - La fuite des jours.osz",
|
@"1428384 DUAL ALTER WORLD - Veracila.osz",
|
||||||
"751972 Cranky - CHASER.osz",
|
@"1442963 PUP - DVP.osz",
|
||||||
"779173 Thaehan - Superpower.osz",
|
@"1460370 Sound Souler - Empty Stars.osz",
|
||||||
"780932 VINXIS - A Centralized View.osz",
|
@"1485184 Koven - Love Wins Again.osz",
|
||||||
"785572 S3RL - I'll See You Again (feat. Chi Chi).osz",
|
@"1496811 T & Sugah - Wicked Days (Cut Ver.).osz",
|
||||||
"785650 yuki. feat. setsunan - Hello! World.osz",
|
@"1501511 Masahiro ""Godspeed"" Aoki - Frostbite (Cut Ver.).osz",
|
||||||
"785677 Dictate - Militant.osz",
|
@"1511518 T & Sugah X Zazu - Lost On My Own (Cut Ver.).osz",
|
||||||
"785731 S3RL - Catchit (Radio Edit).osz",
|
@"1516617 wotoha - Digital Life Hacker.osz",
|
||||||
"785774 LukHash - GLITCH.osz",
|
@"1524273 Michael Cera Palin - Admiral.osz",
|
||||||
"786498 Trial & Error - Tokoyami no keiyaku KEGARETA-SHOUJO feat. GUMI.osz",
|
@"1564234 P4koo - Fly High (feat. rerone).osz",
|
||||||
"789374 Pulse - LP.osz",
|
@"1572918 Lexurus - Take Me Away (Cut Ver.).osz",
|
||||||
"789528 James Portland - Sky.osz",
|
@"1577313 Kurubukko - The 84th Flight.osz",
|
||||||
"789529 Lexurus - Gravity.osz",
|
@"1587839 Amidst - Droplet.osz",
|
||||||
"789544 Andromedik - Invasion.osz",
|
@"1595193 BlackY - Sakura Ranman Cleopatra.osz",
|
||||||
"789905 Gourski x Himmes - Silence.osz",
|
@"1667560 xi - FREEDOM DiVE.osz",
|
||||||
"791667 cYsmix - Babaroque (Short Ver.).osz",
|
@"1668789 City Girl - L2M (feat. Kelsey Kuan).osz",
|
||||||
"791798 cYsmix - Behind the Walls.osz",
|
@"1672934 xi - Parousia.osz",
|
||||||
"791845 cYsmix - Little Knight.osz",
|
@"1673457 Boom Kitty - Any Other Way (feat. Ivy Marie).osz",
|
||||||
"792241 cYsmix - Eden.osz",
|
@"1685122 xi - Time files.osz",
|
||||||
"792396 cYsmix - The Ballad of a Mindless Girl.osz",
|
@"1689372 NIWASHI - Y.osz",
|
||||||
"795432 Phonetic - Journey.osz",
|
@"1729551 JOYLESS - Dream.osz",
|
||||||
"831322 DJ'TEKINA//SOMETHING - Hidamari no Uta.osz",
|
@"1742868 Ritorikal - Synergy.osz",
|
||||||
"847764 Cranky - Crocus.osz",
|
@"1757511 KINEMA106 - KARASU.osz",
|
||||||
"847776 Culprate & Joe Ford - Gaucho.osz",
|
@"1778169 Ricky Montgomery - Cabo.osz",
|
||||||
"847812 J. Pachelbel - Canon (Cranky Remix).osz",
|
@"1848184 FRASER EDWARDS - Ruination.osz",
|
||||||
"847900 Cranky - Time Alter.osz",
|
@"1862574 Pegboard Nerds - Try This (Cut Ver.).osz",
|
||||||
"847930 LukHash - 8BIT FAIRY TALE.osz",
|
@"1873680 happy30 - You spin my world.osz",
|
||||||
"848003 Culprate - Aurora.osz",
|
@"1890055 A.SAKA - Mutsuki Akari no Yuki.osz",
|
||||||
"848068 nanobii - popsicle beach.osz",
|
@"1911933 Marmalade butcher - Waltz for Chroma (feat. Natsushiro Takaaki).osz",
|
||||||
"848090 Trial & Error - DAI*TAN SENSATION feat. Nanahira, Mii, Aitsuki Nakuru (Short Ver.).osz",
|
@"1940007 Mili - Ga1ahad and Scientific Witchery.osz",
|
||||||
"848259 Culprate & Skorpion - Jester.osz",
|
@"1948970 Shadren - You're Here Forever.osz",
|
||||||
"848976 Dictate - Treason.osz",
|
@"1967856 Annabel - alpine blue.osz",
|
||||||
"851543 Culprate - Florn.osz",
|
@"1969316 Silentroom - NULCTRL.osz",
|
||||||
"864748 Thaehan - Angry Birds Epic (Remix).osz",
|
@"1978614 Krimek - Idyllic World.osz",
|
||||||
"873667 OISHII - ONIGIRI FREEWAY.osz",
|
@"1991315 Feint - Tower Of Heaven (You Are Slaves) (Cut Ver.).osz",
|
||||||
"876227 Culprate, Keota & Sophie Meiers - Mechanic Heartbeat.osz",
|
@"1997470 tephe - Genjitsu Escape.osz",
|
||||||
"880487 cYsmix - Peer Gynt.osz",
|
@"1999116 soowamisu - .vaporcore.osz",
|
||||||
"883088 Wisp X - Somewhere I'd Rather Be.osz",
|
@"2010589 Junk - Yellow Smile (bms edit).osz",
|
||||||
"891333 HyuN - White Aura.osz",
|
@"2022054 Yokomin - STINGER.osz",
|
||||||
"891334 HyuN - Wild Card.osz",
|
@"2025686 Aice room - For U.osz",
|
||||||
"891337 HyuN feat. LyuU - Cross Over.osz",
|
@"2035357 C-Show feat. Ishizawa Yukari - Border Line.osz",
|
||||||
"891338 HyuN & Ritoru - Apocalypse in Love.osz",
|
@"2039403 SECONDWALL - Freedom.osz",
|
||||||
"891339 HyuN feat. Ato - Asu wa Ame ga Yamukara.osz",
|
@"2046487 Rameses B - Against the Grain (feat. Veela).osz",
|
||||||
"891345 HyuN - Infinity Heaven.osz",
|
@"2052201 ColBreakz & Vizzen - Remember.osz",
|
||||||
"891348 HyuN - Guitian.osz",
|
@"2055535 Sephid - Thunderstrike 1988.osz",
|
||||||
"891356 HyuN - Legend of Genesis.osz",
|
@"2057584 SAMString - Ataraxia.osz",
|
||||||
"891366 HyuN - Illusion of Inflict.osz",
|
@"2067270 Blue Stahli - The Fall.osz",
|
||||||
"891417 HyuN feat. Yu-A - My life is for you.osz",
|
@"2075039 garlagan - Skyless.osz",
|
||||||
"891441 HyuN - You'Re aRleAdY dEAd.osz",
|
@"2079089 Hamu feat. yuiko - Innocent Letter.osz",
|
||||||
"891632 HyuN feat. YURI - Disorder.osz",
|
@"2082895 FATE GEAR - Heart's Grave.osz",
|
||||||
"891712 HyuN - Tokyo's Starlight.osz",
|
@"2085974 HoneyComeBear - Twilight.osz",
|
||||||
"901091 *namirin - Ciel etoile.osz",
|
@"2094934 F.O.O.L & Laura Brehm - Waking Up.osz",
|
||||||
"916990 *namirin - Koishiteiku Planet.osz",
|
@"2097481 Mameyudoufu - Wave feat. Aitsuki Nakuru.osz",
|
||||||
"929284 tieff - Sense of Nostalgia.osz",
|
@"2106075 MYUKKE. - The 89's Momentum.osz",
|
||||||
"933940 Ben Briggs - Yes (Maybe).osz",
|
@"2117392 t+pazolite & Komiya Mao - Elustametat.osz",
|
||||||
"934415 Ben Briggs - Fearless Living.osz",
|
@"2123533 LeaF - Calamity Fortune.osz",
|
||||||
"934627 Ben Briggs - New Game Plus.osz",
|
@"2143876 Alkome - Your Voice.osz",
|
||||||
"934666 Ben Briggs - Wave Island.osz",
|
@"2145826 Sephid - Cross-D Skyline.osz",
|
||||||
"936126 siromaru + cranky - conflict.osz",
|
@"2153172 Emiru no Aishita Tsukiyo ni Dai San Gensou Kyoku wo - Eternal Bliss.osz",
|
||||||
"940377 onumi - ARROGANCE.osz",
|
|
||||||
"940597 tieff - Take Your Swimsuit.osz",
|
|
||||||
"941085 tieff - Our Story.osz",
|
|
||||||
"949297 tieff - Sunflower.osz",
|
|
||||||
"952380 Ben Briggs - Why Are We Yelling.osz",
|
|
||||||
"954272 *namirin - Kanzen Shouri*Esper Girl.osz",
|
|
||||||
"955866 KIRA & Heartbreaker - B.B.F (feat. Hatsune Miku & Kagamine Rin).osz",
|
|
||||||
"961320 Kuba Oms - All In All.osz",
|
|
||||||
"964553 The Flashbulb - You Take the World's Weight Away.osz",
|
|
||||||
"965651 Fractal Dreamers - Ad Astra.osz",
|
|
||||||
"966225 The Flashbulb - Passage D.osz",
|
|
||||||
"966324 DJ'TEKINA//SOMETHING - Hidamari no Uta.osz",
|
|
||||||
"972810 James Landino & Kabuki - Birdsong.osz",
|
|
||||||
"972932 James Landino - Hide And Seek.osz",
|
|
||||||
"977276 The Flashbulb - Mellann.osz",
|
|
||||||
"981616 *namirin - Mizutamari Tobikoete (with Nanahira).osz",
|
|
||||||
"985788 Loki - Wizard's Tower.osz",
|
|
||||||
"996628 OISHII - ONIGIRI FREEWAY.osz",
|
|
||||||
"996898 HyuN - White Aura.osz",
|
|
||||||
"1003554 yuki. - Nadeshiko Sensation.osz",
|
|
||||||
"1014936 Thaehan - Bwa !.osz",
|
|
||||||
"1019827 UNDEAD CORPORATION - Sad Dream.osz",
|
|
||||||
"1020213 Creo - Idolize.osz",
|
|
||||||
"1021450 Thaehan - Chiptune & Baroque.osz",
|
|
||||||
};
|
};
|
||||||
|
|
||||||
private static readonly string[] bundled_taiko =
|
private static readonly string[] bundled_taiko =
|
||||||
{
|
{
|
||||||
"707824 Fractal Dreamers - Fortuna Redux.osz",
|
"1048153 Chroma - [@__@].osz",
|
||||||
"789553 Cranky - Ran.osz",
|
"1229307 Venetian Snares - Shaky Sometimes.osz",
|
||||||
"827822 Function Phantom - Neuronecia.osz",
|
"1236083 meganeko - Sirius A (osu! edit).osz",
|
||||||
"847323 Nakanojojo - Bittersweet (feat. Kuishinboakachan a.k.a Kiato).osz",
|
"1248594 Noisia - Anomaly.osz",
|
||||||
"847433 Trial & Error - Tokoyami no keiyaku KEGARETA-SHOUJO feat. GUMI.osz",
|
"1272851 siqlo - One Way Street.osz",
|
||||||
"847576 dark cat - hot chocolate.osz",
|
"1290736 Kola Kid - good old times.osz",
|
||||||
"847957 Wisp X - Final Moments.osz",
|
"1318825 SECONDWALL - Light.osz",
|
||||||
"876282 VINXIS - Greetings.osz",
|
"1320872 MYUKKE. - The 89's Momentum.osz",
|
||||||
"876648 Thaehan - Angry Birds Epic (Remix).osz",
|
"1337389 cute girls doing cute things - Main Heroine.osz",
|
||||||
"877069 IAHN - Transform (Original Mix).osz",
|
"1397782 Reku Mochizuki - Yorixiro.osz",
|
||||||
"877496 Thaehan - Leprechaun.osz",
|
"1407228 II-L - VANGUARD-1.osz",
|
||||||
"877935 Thaehan - Overpowered.osz",
|
"1422686 II-L - VANGUARD-2.osz",
|
||||||
"878344 yuki. - Be Your Light.osz",
|
"1429217 Street - Phi.osz",
|
||||||
"918446 VINXIS - Facade.osz",
|
"1442235 2ToneDisco x Cosmicosmo - Shoelaces (feat. Puniden).osz",
|
||||||
"918903 LukHash - Ghosts.osz",
|
"1447478 Cres. - End Time.osz",
|
||||||
"919251 *namirin - Hitokoto no Kyori.osz",
|
"1449942 m108 - Crescent Sakura.osz",
|
||||||
"919704 S3RL - I Will Pick You Up (feat. Tamika).osz",
|
"1463778 MuryokuP - A tree without a branch.osz",
|
||||||
"921535 SOOOO - Raven Haven.osz",
|
"1465152 fiend - Fever Dream (feat. yzzyx).osz",
|
||||||
"927206 *namirin - Kanzen Shouri*Esper Girl.osz",
|
"1472397 MYUKKE. - Boudica.osz",
|
||||||
"927544 Camellia feat. Nanahira - Kansoku Eisei.osz",
|
"1488148 Aoi vs. siqlo - Hacktivism.osz",
|
||||||
"930806 Nakanojojo - Pararara (feat. Amekoya).osz",
|
"1522733 wotoha - Digital Life Hacker.osz",
|
||||||
"931741 Camellia - Quaoar.osz",
|
"1540010 Marmalade butcher - Floccinaucinihilipilification.osz",
|
||||||
"935699 Rin - Mythic set ~ Heart-Stirring Urban Legends.osz",
|
"1584690 MYUKKE. - AKKERA-COUNTRY-BOY.osz",
|
||||||
"935732 Thaehan - Yuujou.osz",
|
"1608857 BLOOD STAIN CHILD - S.O.P.H.I.A.osz",
|
||||||
"941145 Function Phantom - Euclid.osz",
|
"1609365 Reku Mochizuki - Faith of Eastward.osz",
|
||||||
"942334 Dictate - Cauldron.osz",
|
"1622545 METAROOM - I - DINKI THE STARGUIDE.osz",
|
||||||
"946540 nanobii - astral blast.osz",
|
"1629336 METAROOM - PINK ORIGINS.osz",
|
||||||
"948844 Rin - Kishinjou set 01 ~ Mist Lake.osz",
|
"1644680 Neko Hacker - Pictures feat. 4s4ki.osz",
|
||||||
"949122 Wisp X - Petal.osz",
|
"1650835 RiraN - Ready For The Madness.osz",
|
||||||
"951618 Rin - Kishinjou set 02 ~ Mermaid from the Uncharted Land.osz",
|
"1661508 PTB10 - Starfall.osz",
|
||||||
"957412 Rin - Lunatic set 16 ~ The Space Shrine Maiden Returns Home.osz",
|
"1671987 xi - World Fragments II.osz",
|
||||||
"961335 Thaehan - Insert Coin.osz",
|
"1703065 tokiwa - wasurena feat. Sennzai.osz",
|
||||||
"965178 The Flashbulb - DIDJ PVC.osz",
|
"1703527 tokiwa feat. Nakamura Sanso - Kotodama Refrain.osz",
|
||||||
"966087 The Flashbulb - Creep.osz",
|
"1704340 A-One feat. Shihori - Magic Girl !!.osz",
|
||||||
"966277 The Flashbulb - Amen Iraq.osz",
|
"1712783 xi - Parousia.osz",
|
||||||
"966407 LukHash - ROOM 12.osz",
|
"1718774 Harumaki Gohan - Suisei ni Nareta nara.osz",
|
||||||
"966451 The Flashbulb - Six Acid Strings.osz",
|
"1719687 EmoCosine - Love Kills U.osz",
|
||||||
"972301 BilliumMoto - four veiled stars.osz",
|
"1733940 WHITEFISTS feat. Sennzai - Paralyzed Ash.osz",
|
||||||
"973173 nanobii - popsicle beach.osz",
|
"1734692 EmoCosine - Cutter.osz",
|
||||||
"973954 BilliumMoto - Rocky Buinne (Short Ver.).osz",
|
"1739529 luvlxckdown - tbh i dont like being social.osz",
|
||||||
"975435 BilliumMoto - life flashes before weeb eyes.osz",
|
"1756970 Kurubukko vs. yukitani - Minamichita EVOLVED.osz",
|
||||||
"978759 L. V. Beethoven - Moonlight Sonata (Cranky Remix).osz",
|
"1762209 Marmalade butcher - Immortality Math Club.osz",
|
||||||
"982559 BilliumMoto - HDHR.osz",
|
"1765720 ZxNX - FORTALiCE.osz",
|
||||||
"984361 The Flashbulb - Ninedump.osz",
|
"1786165 NILFRUITS - Arandano.osz",
|
||||||
"1023681 Inferi - The Ruin of Mankind.osz",
|
"1787258 SAMString - Night Fighter.osz",
|
||||||
"1034358 ALEPH - The Evil Spirit.osz",
|
"1791462 ZxNX - Schadenfreude.osz",
|
||||||
"1037567 ALEPH - Scintillations.osz",
|
"1793821 Kobaryo - The Lightning Sword.osz",
|
||||||
|
"1796440 kuru x miraie - re:start.osz",
|
||||||
|
"1799285 Origami Angel - 666 Flags.osz",
|
||||||
|
"1812415 nanobii - Rainbow Road.osz",
|
||||||
|
"1814682 NIWASHI - Y.osz",
|
||||||
|
"1818361 meganeko - Feral (osu! edit).osz",
|
||||||
|
"1818924 fiend - Disconnect.osz",
|
||||||
|
"1838730 Pegboard Nerds - Disconnected.osz",
|
||||||
|
"1854710 Blaster & Extra Terra - Spacecraft (Cut Ver.).osz",
|
||||||
|
"1859322 Hino Isuka - Delightness Brightness.osz",
|
||||||
|
"1884102 Maduk - Go (feat. Lachi) (Cut Ver.).osz",
|
||||||
|
"1884578 Neko Hacker - People People feat. Nanahira.osz",
|
||||||
|
"1897902 uma vs. Morimori Atsushi - Re: End of a Dream.osz",
|
||||||
|
"1905582 KINEMA106 - Fly Away (Cut Ver.).osz",
|
||||||
|
"1934686 ARForest - Rainbow Magic!!.osz",
|
||||||
|
"1963076 METAROOM - S.N.U.F.F.Y.osz",
|
||||||
|
"1968973 Stars Hollow - Out the Sunroof..osz",
|
||||||
|
"1971951 James Landino - Shiba Paradise.osz",
|
||||||
|
"1972518 Toromaru - Sleight of Hand.osz",
|
||||||
|
"1982302 KINEMA106 - INVITE.osz",
|
||||||
|
"1983475 KNOWER - The Government Knows.osz",
|
||||||
|
"2010165 Junk - Yellow Smile (bms edit).osz",
|
||||||
|
"2022737 Andora - Euphoria (feat. WaMi).osz",
|
||||||
|
"2025023 tephe - Genjitsu Escape.osz",
|
||||||
|
"2052754 P4koo - 8th:Planet ~Re:search~.osz",
|
||||||
|
"2054122 Raimukun - Myths Orbis.osz",
|
||||||
|
"2121470 Raimukun - Nyarlathotep's Dreamland.osz",
|
||||||
|
"2122284 Agressor Bunx - Tornado (Cut Ver.).osz",
|
||||||
|
"2125034 Agressor Bunx - Acid Mirage (Cut Ver.).osz",
|
||||||
|
"2136263 Se-U-Ra - Cris Fortress.osz",
|
||||||
};
|
};
|
||||||
|
|
||||||
private static readonly string[] bundled_catch =
|
private static readonly string[] bundled_catch =
|
||||||
{
|
{
|
||||||
"554256 Helblinde - When Time Sleeps.osz",
|
@"693123 yuki. - Nadeshiko Sensation.osz",
|
||||||
"693123 yuki. - Nadeshiko Sensation.osz",
|
@"833719 FOLiACETATE - Heterochromia Iridis.osz",
|
||||||
"767009 OISHII - PIZZA PLAZA.osz",
|
@"981762 siromaru + cranky - conflict.osz",
|
||||||
"767346 Thaehan - Bwa !.osz",
|
@"1008600 LukHash - WHEN AN ANGEL DIES.osz",
|
||||||
"815162 VINXIS - Greetings.osz",
|
@"1071294 dark cat - pursuit of happiness.osz",
|
||||||
"840964 cYsmix - Breeze.osz",
|
@"1102115 meganeko - Nova.osz",
|
||||||
"932657 Wisp X - Eventide.osz",
|
@"1115500 Chopin - Etude Op. 25, No. 12 (meganeko Remix).osz",
|
||||||
"933700 onumi - CONFUSION PART ONE.osz",
|
@"1128274 LeaF - Wizdomiot.osz",
|
||||||
"933984 onumi - PERSONALITY.osz",
|
@"1141049 HyuN feat. JeeE - Fallen Angel.osz",
|
||||||
"934785 onumi - FAKE.osz",
|
@"1148215 Zekk - Fluctuation.osz",
|
||||||
"936545 onumi - REGRET PART ONE.osz",
|
@"1151833 ginkiha - nightfall.osz",
|
||||||
"943803 Fractal Dreamers - Everything for a Dream.osz",
|
@"1158124 PUP - Dark Days.osz",
|
||||||
"943876 S3RL - I Will Pick You Up (feat. Tamika).osz",
|
@"1184890 IAHN - Transform (Original Mix).osz",
|
||||||
"946773 Trial & Error - DREAMING COLOR (Short Ver.).osz",
|
@"1195922 Disasterpeace - Home.osz",
|
||||||
"955808 Trial & Error - Tokoyami no keiyaku KEGARETA-SHOUJO feat. GUMI (Short Ver.).osz",
|
@"1197461 MIMI - Nanimo nai Youna.osz",
|
||||||
"957808 Fractal Dreamers - Module_410.osz",
|
@"1197924 Camellia feat. Nanahira - Looking For A New Adventure.osz",
|
||||||
"957842 antiPLUR - One Life Left to Live.osz",
|
@"1203594 ginkiha - Anemoi.osz",
|
||||||
"965730 The Flashbulb - Lawn Wake IV (Black).osz",
|
@"1211572 MIMI - Lapis Lazuli.osz",
|
||||||
"966240 Creo - Challenger.osz",
|
@"1231601 Lime - Harmony.osz",
|
||||||
"968232 Rin - Lunatic set 15 ~ The Moon as Seen from the Shrine.osz",
|
@"1240162 P4koo - 8th:Planet ~Re:search~.osz",
|
||||||
"972302 VINXIS - A Centralized View.osz",
|
@"1246000 Zekk - Calling.osz",
|
||||||
"972887 HyuN - Illusion of Inflict.osz",
|
@"1249928 Thaehan - Yuujou.osz",
|
||||||
"1008600 LukHash - WHEN AN ANGEL DIES.osz",
|
@"1258751 Umeboshi Chazuke - ICHIBANBOSHI*ROCKET.osz",
|
||||||
"1032103 LukHash - H8 U.osz",
|
@"1264818 Umeboshi Chazuke - Panic! Pop'n! Picnic! (2019 REMASTER).osz",
|
||||||
|
@"1280183 IAHN - Mad Halloween.osz",
|
||||||
|
@"1303201 Umeboshi Chazuke - Run*2 Run To You!!.osz",
|
||||||
|
@"1328918 Kobaryo - Theme for Psychopath Justice.osz",
|
||||||
|
@"1338215 Lime - Renai Syndrome.osz",
|
||||||
|
@"1338796 uma vs. Morimori Atsushi - Re:End of a Dream.osz",
|
||||||
|
@"1340492 MYUKKE. - The 89's Momentum.osz",
|
||||||
|
@"1393933 Mastermind (xi+nora2r) - Dreadnought.osz",
|
||||||
|
@"1400205 m108 - XIII Charlotte.osz",
|
||||||
|
@"1471328 Lime - Chronomia.osz",
|
||||||
|
@"1503591 Origami Angel - The Title Track.osz",
|
||||||
|
@"1524173 litmus* as Ester - Krave.osz",
|
||||||
|
@"1541235 Getty vs. DJ DiA - Grayed Out -Antifront-.osz",
|
||||||
|
@"1554250 Shawn Wasabi - Otter Pop (feat. Hollis).osz",
|
||||||
|
@"1583461 Sound Souler - Absent Color.osz",
|
||||||
|
@"1638487 tokiwa - wasurena feat. Sennzai.osz",
|
||||||
|
@"1698949 ZxNX - Schadenfreude.osz",
|
||||||
|
@"1704324 xi - Time files.osz",
|
||||||
|
@"1756405 Fractal Dreamers - Kingdom of Silence.osz",
|
||||||
|
@"1769575 cYsmix - Peer Gynt.osz",
|
||||||
|
@"1770054 Ardolf - Split.osz",
|
||||||
|
@"1772648 in love with a ghost - interdimensional portal leading to a cute place feat. snail's house.osz",
|
||||||
|
@"1776379 in love with a ghost - i thought we were lovers w/ basil.osz",
|
||||||
|
@"1779476 URBANGARDE - KIMI WA OKUMAGASO.osz",
|
||||||
|
@"1789435 xi - Parousia.osz",
|
||||||
|
@"1794190 Se-U-Ra - The Endless for Traveler.osz",
|
||||||
|
@"1799889 Waterflame - Ricochet Love.osz",
|
||||||
|
@"1816401 Gram vs. Yooh - Apocalypse.osz",
|
||||||
|
@"1826327 -45 - Total Eclipse of The Sun.osz",
|
||||||
|
@"1830796 xi - Halcyon.osz",
|
||||||
|
@"1924231 Mili - Nine Point Eight.osz",
|
||||||
|
@"1952903 Cres. - End Time.osz",
|
||||||
|
@"1970946 Good Kid - Slingshot.osz",
|
||||||
|
@"1982063 linear ring - enchanted love.osz",
|
||||||
|
@"2000438 Toromaru - Erinyes.osz",
|
||||||
|
@"2124277 II-L - VANGUARD-3.osz",
|
||||||
|
@"2147529 Nashimoto Ui - AaAaAaAAaAaAAa (Cut Ver.).osz",
|
||||||
};
|
};
|
||||||
|
|
||||||
private static readonly string[] bundled_mania =
|
private static readonly string[] bundled_mania =
|
||||||
{
|
{
|
||||||
"943516 antiPLUR - Clockwork Spooks.osz",
|
@"1008419 BilliumMoto - Four Veiled Stars.osz",
|
||||||
"946394 VINXIS - Three Times The Original Charm.osz",
|
@"1025170 Frums - We Want To Run.osz",
|
||||||
"966408 antiPLUR - One Life Left to Live.osz",
|
@"1092856 F-777 - Viking Arena.osz",
|
||||||
"971561 antiPLUR - Runengon.osz",
|
@"1139247 O2i3 - Heart Function.osz",
|
||||||
"983864 James Landino - Shiba Island.osz",
|
@"1154007 LeaF - ATHAZA.osz",
|
||||||
"989512 BilliumMoto - 1xMISS.osz",
|
@"1170054 Zekk - Fallen.osz",
|
||||||
"994104 James Landino - Reaction feat. Slyleaf.osz",
|
@"1212132 Street - Koiyamai (TV Size).osz",
|
||||||
"1003217 nekodex - circles!.osz",
|
@"1226466 Se-U-Ra - Elif to Shiro Kura no Yoru -Called-.osz",
|
||||||
"1009907 James Landino & Kabuki - Birdsong.osz",
|
@"1247210 Frums - Credits.osz",
|
||||||
"1015169 Thaehan - Insert Coin.osz",
|
@"1254196 ARForest - Regret.osz",
|
||||||
|
@"1258829 Umeboshi Chazuke - Cineraria.osz",
|
||||||
|
@"1300398 ARForest - The Last Page.osz",
|
||||||
|
@"1305627 Frums - Star of the COME ON!!.osz",
|
||||||
|
@"1348806 Se-U-Ra - LOA2.osz",
|
||||||
|
@"1375449 yuki. - Nadeshiko Sensation.osz",
|
||||||
|
@"1448292 Cres. - End Time.osz",
|
||||||
|
@"1479741 Reku Mochizuki - FORViDDEN ENERZY -Fataldoze-.osz",
|
||||||
|
@"1494747 Fractal Dreamers - Whispers from a Distant Star.osz",
|
||||||
|
@"1505336 litmus* - Rush-More.osz",
|
||||||
|
@"1508963 ARForest - Rainbow Magic!!.osz",
|
||||||
|
@"1727126 Chroma - Strange Inventor.osz",
|
||||||
|
@"1737101 ZxNX - FORTALiCE.osz",
|
||||||
|
@"1740952 Sobrem x Silentroom - Random.osz",
|
||||||
|
@"1756251 Plum - Mad Piano Party.osz",
|
||||||
|
@"1909163 Frums - theyaremanycolors.osz",
|
||||||
|
@"1916285 siromaru + cranky - conflict.osz",
|
||||||
|
@"1948972 Ardolf - Split.osz",
|
||||||
|
@"1957138 GLORYHAMMER - Rise Of The Chaos Wizards.osz",
|
||||||
|
@"1972411 James Landino - Shiba Paradise.osz",
|
||||||
|
@"1978179 Andora - Flicker (feat. RANASOL).osz",
|
||||||
|
@"1987180 cygnus - The Evolution of War.osz",
|
||||||
|
@"1994458 tephe - Genjitsu Escape.osz",
|
||||||
|
@"1999339 Aice room - Nyan Nyan Dive (EmoCosine Remix).osz",
|
||||||
|
@"2015361 HoneyComeBear - Rainy Girl.osz",
|
||||||
|
@"2028108 HyuN - Infinity Heaven.osz",
|
||||||
|
@"2055329 miraie & blackwinterwells - facade.osz",
|
||||||
|
@"2069877 Sephid - Thunderstrike 1988.osz",
|
||||||
|
@"2119716 Aethoro - Snowy.osz",
|
||||||
|
@"2120379 Synthion - VIVIDVELOCITY.osz",
|
||||||
|
@"2124805 Frums (unknown ""lambda"") - 19ZZ.osz",
|
||||||
|
@"2127811 Wiklund - Joy of Living (Cut Ver.).osz",
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -39,6 +39,11 @@ namespace osu.Game.Localisation
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public static LocalisableString BundledButton => new TranslatableString(getKey(@"bundled_button"), @"Get recommended beatmaps");
|
public static LocalisableString BundledButton => new TranslatableString(getKey(@"bundled_button"), @"Get recommended beatmaps");
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// "Beatmaps will be downloaded in the background. You can continue with setup while this happens!"
|
||||||
|
/// </summary>
|
||||||
|
public static LocalisableString DownloadingInBackground => new TranslatableString(getKey(@"downloading_in_background"), @"Beatmaps will be downloaded in the background. You can continue with setup while this happens!");
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// "You can also obtain more beatmaps from the main menu "browse" button at any time."
|
/// "You can also obtain more beatmaps from the main menu "browse" button at any time."
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -15,6 +15,7 @@ using osu.Game.Graphics.Containers;
|
|||||||
using osu.Game.Localisation;
|
using osu.Game.Localisation;
|
||||||
using osu.Game.Online;
|
using osu.Game.Online;
|
||||||
using osuTK;
|
using osuTK;
|
||||||
|
using osuTK.Graphics;
|
||||||
using Realms;
|
using Realms;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.FirstRunSetup
|
namespace osu.Game.Overlays.FirstRunSetup
|
||||||
@ -25,6 +26,8 @@ namespace osu.Game.Overlays.FirstRunSetup
|
|||||||
private ProgressRoundedButton downloadBundledButton = null!;
|
private ProgressRoundedButton downloadBundledButton = null!;
|
||||||
private ProgressRoundedButton downloadTutorialButton = null!;
|
private ProgressRoundedButton downloadTutorialButton = null!;
|
||||||
|
|
||||||
|
private OsuTextFlowContainer downloadInBackgroundText = null!;
|
||||||
|
|
||||||
private OsuTextFlowContainer currentlyLoadedBeatmaps = null!;
|
private OsuTextFlowContainer currentlyLoadedBeatmaps = null!;
|
||||||
|
|
||||||
private BundledBeatmapDownloader? tutorialDownloader;
|
private BundledBeatmapDownloader? tutorialDownloader;
|
||||||
@ -100,6 +103,15 @@ namespace osu.Game.Overlays.FirstRunSetup
|
|||||||
Text = FirstRunSetupBeatmapScreenStrings.BundledButton,
|
Text = FirstRunSetupBeatmapScreenStrings.BundledButton,
|
||||||
Action = downloadBundled
|
Action = downloadBundled
|
||||||
},
|
},
|
||||||
|
downloadInBackgroundText = new OsuTextFlowContainer(cp => cp.Font = OsuFont.Default.With(size: CONTENT_FONT_SIZE))
|
||||||
|
{
|
||||||
|
Colour = OverlayColourProvider.Light2,
|
||||||
|
Alpha = 0,
|
||||||
|
TextAnchor = Anchor.TopCentre,
|
||||||
|
Text = FirstRunSetupBeatmapScreenStrings.DownloadingInBackground,
|
||||||
|
RelativeSizeAxes = Axes.X,
|
||||||
|
AutoSizeAxes = Axes.Y
|
||||||
|
},
|
||||||
new OsuTextFlowContainer(cp => cp.Font = OsuFont.Default.With(size: CONTENT_FONT_SIZE))
|
new OsuTextFlowContainer(cp => cp.Font = OsuFont.Default.With(size: CONTENT_FONT_SIZE))
|
||||||
{
|
{
|
||||||
Colour = OverlayColourProvider.Content1,
|
Colour = OverlayColourProvider.Content1,
|
||||||
@ -169,6 +181,10 @@ namespace osu.Game.Overlays.FirstRunSetup
|
|||||||
if (bundledDownloader != null)
|
if (bundledDownloader != null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
downloadInBackgroundText
|
||||||
|
.FlashColour(Color4.White, 500)
|
||||||
|
.FadeIn(200);
|
||||||
|
|
||||||
bundledDownloader = new BundledBeatmapDownloader(false);
|
bundledDownloader = new BundledBeatmapDownloader(false);
|
||||||
|
|
||||||
AddInternal(bundledDownloader);
|
AddInternal(bundledDownloader);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using osu.Framework;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Sprites;
|
using osu.Framework.Graphics.Sprites;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
@ -25,8 +26,10 @@ namespace osu.Game.Overlays.Settings.Sections
|
|||||||
{
|
{
|
||||||
new WebSettings(),
|
new WebSettings(),
|
||||||
new AlertsAndPrivacySettings(),
|
new AlertsAndPrivacySettings(),
|
||||||
new IntegrationSettings()
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (RuntimeInfo.IsDesktop)
|
||||||
|
Add(new IntegrationSettings());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -40,7 +40,9 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
|
|
||||||
public override bool Contains(Vector2 screenSpacePos) => drawableQuad.Contains(screenSpacePos);
|
public override bool Contains(Vector2 screenSpacePos) => drawableQuad.Contains(screenSpacePos);
|
||||||
|
|
||||||
public override Vector2 ScreenSpaceSelectionPoint => drawable.ToScreenSpace(drawable.OriginPosition);
|
public override Vector2 ScreenSpaceSelectionPoint =>
|
||||||
|
// Important to use a stable position (not based on origin) as origin may be automatically updated during drag operations.
|
||||||
|
drawable.ScreenSpaceDrawQuad.Centre;
|
||||||
|
|
||||||
protected override bool ReceivePositionalInputAtSubTree(Vector2 screenSpacePos) =>
|
protected override bool ReceivePositionalInputAtSubTree(Vector2 screenSpacePos) =>
|
||||||
drawableQuad.Contains(screenSpacePos);
|
drawableQuad.Contains(screenSpacePos);
|
||||||
|
@ -457,7 +457,7 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
}
|
}
|
||||||
|
|
||||||
SelectedComponents.Add(component);
|
SelectedComponents.Add(component);
|
||||||
SkinSelectionHandler.ApplyClosestAnchor(drawableComponent);
|
SkinSelectionHandler.ApplyClosestAnchorOrigin(drawableComponent);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -540,7 +540,7 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
|
|
||||||
protected void Redo() => changeHandler?.RestoreState(1);
|
protected void Redo() => changeHandler?.RestoreState(1);
|
||||||
|
|
||||||
public void Save(bool userTriggered = true) => save(currentSkin.Value);
|
public void Save(bool userTriggered = true) => save(currentSkin.Value, userTriggered);
|
||||||
|
|
||||||
private void save(Skin skin, bool userTriggered = true)
|
private void save(Skin skin, bool userTriggered = true)
|
||||||
{
|
{
|
||||||
|
@ -13,6 +13,7 @@ using osu.Framework.Graphics.Primitives;
|
|||||||
using osu.Framework.Input;
|
using osu.Framework.Input;
|
||||||
using osu.Framework.Input.Bindings;
|
using osu.Framework.Input.Bindings;
|
||||||
using osu.Framework.Input.Events;
|
using osu.Framework.Input.Events;
|
||||||
|
using osu.Framework.Layout;
|
||||||
using osu.Framework.Screens;
|
using osu.Framework.Screens;
|
||||||
using osu.Framework.Testing;
|
using osu.Framework.Testing;
|
||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
@ -30,7 +31,6 @@ using osu.Game.Screens.Play;
|
|||||||
using osu.Game.Screens.Select;
|
using osu.Game.Screens.Select;
|
||||||
using osu.Game.Users;
|
using osu.Game.Users;
|
||||||
using osu.Game.Utils;
|
using osu.Game.Utils;
|
||||||
using osuTK;
|
|
||||||
|
|
||||||
namespace osu.Game.Overlays.SkinEditor
|
namespace osu.Game.Overlays.SkinEditor
|
||||||
{
|
{
|
||||||
@ -70,12 +70,14 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
private OsuScreen? lastTargetScreen;
|
private OsuScreen? lastTargetScreen;
|
||||||
private InvokeOnDisposal? nestedInputManagerDisable;
|
private InvokeOnDisposal? nestedInputManagerDisable;
|
||||||
|
|
||||||
private Vector2 lastDrawSize;
|
private readonly LayoutValue drawSizeLayout;
|
||||||
|
|
||||||
public SkinEditorOverlay(ScalingContainer scalingContainer)
|
public SkinEditorOverlay(ScalingContainer scalingContainer)
|
||||||
{
|
{
|
||||||
this.scalingContainer = scalingContainer;
|
this.scalingContainer = scalingContainer;
|
||||||
RelativeSizeAxes = Axes.Both;
|
RelativeSizeAxes = Axes.Both;
|
||||||
|
|
||||||
|
AddLayout(drawSizeLayout = new LayoutValue(Invalidation.DrawSize));
|
||||||
}
|
}
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
@ -199,10 +201,10 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
{
|
{
|
||||||
base.Update();
|
base.Update();
|
||||||
|
|
||||||
if (game.DrawSize != lastDrawSize)
|
if (!drawSizeLayout.IsValid)
|
||||||
{
|
{
|
||||||
lastDrawSize = game.DrawSize;
|
|
||||||
updateScreenSizing();
|
updateScreenSizing();
|
||||||
|
drawSizeLayout.Validate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,6 +23,8 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
{
|
{
|
||||||
public partial class SkinSelectionHandler : SelectionHandler<ISerialisableDrawable>
|
public partial class SkinSelectionHandler : SelectionHandler<ISerialisableDrawable>
|
||||||
{
|
{
|
||||||
|
private OsuMenuItem originMenu = null!;
|
||||||
|
|
||||||
[Resolved]
|
[Resolved]
|
||||||
private SkinEditor skinEditor { get; set; } = null!;
|
private SkinEditor skinEditor { get; set; } = null!;
|
||||||
|
|
||||||
@ -137,7 +139,7 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
var drawableItem = (Drawable)b.Item;
|
var drawableItem = (Drawable)b.Item;
|
||||||
|
|
||||||
// each drawable's relative position should be maintained in the scaled quad.
|
// each drawable's relative position should be maintained in the scaled quad.
|
||||||
var screenPosition = b.ScreenSpaceSelectionPoint;
|
var screenPosition = drawableItem.ToScreenSpace(drawableItem.OriginPosition);
|
||||||
|
|
||||||
var relativePositionInOriginal =
|
var relativePositionInOriginal =
|
||||||
new Vector2(
|
new Vector2(
|
||||||
@ -202,17 +204,22 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
var item = c.Item;
|
var item = c.Item;
|
||||||
Drawable drawable = (Drawable)item;
|
Drawable drawable = (Drawable)item;
|
||||||
|
|
||||||
|
if (!item.UsesFixedAnchor)
|
||||||
|
ApplyClosestAnchorOrigin(drawable);
|
||||||
|
|
||||||
drawable.Position += drawable.ScreenSpaceDeltaToParentSpace(moveEvent.ScreenSpaceDelta);
|
drawable.Position += drawable.ScreenSpaceDeltaToParentSpace(moveEvent.ScreenSpaceDelta);
|
||||||
|
|
||||||
if (item.UsesFixedAnchor) continue;
|
|
||||||
|
|
||||||
ApplyClosestAnchor(drawable);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void ApplyClosestAnchor(Drawable drawable) => applyAnchor(drawable, getClosestAnchor(drawable));
|
public static void ApplyClosestAnchorOrigin(Drawable drawable)
|
||||||
|
{
|
||||||
|
var closest = getClosestAnchor(drawable);
|
||||||
|
|
||||||
|
applyAnchor(drawable, closest);
|
||||||
|
applyOrigin(drawable, closest);
|
||||||
|
}
|
||||||
|
|
||||||
protected override void OnSelectionChanged()
|
protected override void OnSelectionChanged()
|
||||||
{
|
{
|
||||||
@ -243,10 +250,15 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
.ToArray()
|
.ToArray()
|
||||||
};
|
};
|
||||||
|
|
||||||
yield return new OsuMenuItem("Origin")
|
yield return originMenu = new OsuMenuItem("Origin");
|
||||||
|
|
||||||
|
closestItem.State.BindValueChanged(s =>
|
||||||
{
|
{
|
||||||
Items = createAnchorItems((d, o) => ((Drawable)d).Origin == o, applyOrigins).ToArray()
|
// For UX simplicity, origin should only be user-editable when "closest" anchor mode is disabled.
|
||||||
};
|
originMenu.Items = s.NewValue == TernaryState.True
|
||||||
|
? Array.Empty<MenuItem>()
|
||||||
|
: createAnchorItems((d, o) => ((Drawable)d).Origin == o, applyOrigins).ToArray();
|
||||||
|
}, true);
|
||||||
|
|
||||||
yield return new OsuMenuItemSpacer();
|
yield return new OsuMenuItemSpacer();
|
||||||
|
|
||||||
@ -325,15 +337,10 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
{
|
{
|
||||||
var drawable = (Drawable)item;
|
var drawable = (Drawable)item;
|
||||||
|
|
||||||
if (origin == drawable.Origin) continue;
|
applyOrigin(drawable, origin);
|
||||||
|
|
||||||
var previousOrigin = drawable.OriginPosition;
|
if (!item.UsesFixedAnchor)
|
||||||
drawable.Origin = origin;
|
ApplyClosestAnchorOrigin(drawable);
|
||||||
drawable.Position += drawable.OriginPosition - previousOrigin;
|
|
||||||
|
|
||||||
if (item.UsesFixedAnchor) continue;
|
|
||||||
|
|
||||||
ApplyClosestAnchor(drawable);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
OnOperationEnded();
|
OnOperationEnded();
|
||||||
@ -368,7 +375,7 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
foreach (var item in SelectedItems)
|
foreach (var item in SelectedItems)
|
||||||
{
|
{
|
||||||
item.UsesFixedAnchor = false;
|
item.UsesFixedAnchor = false;
|
||||||
ApplyClosestAnchor((Drawable)item);
|
ApplyClosestAnchorOrigin((Drawable)item);
|
||||||
}
|
}
|
||||||
|
|
||||||
OnOperationEnded();
|
OnOperationEnded();
|
||||||
@ -414,6 +421,15 @@ namespace osu.Game.Overlays.SkinEditor
|
|||||||
drawable.Position -= drawable.AnchorPosition - previousAnchor;
|
drawable.Position -= drawable.AnchorPosition - previousAnchor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void applyOrigin(Drawable drawable, Anchor origin)
|
||||||
|
{
|
||||||
|
if (origin == drawable.Origin) return;
|
||||||
|
|
||||||
|
var previousOrigin = drawable.OriginPosition;
|
||||||
|
drawable.Origin = origin;
|
||||||
|
drawable.Position += drawable.OriginPosition - previousOrigin;
|
||||||
|
}
|
||||||
|
|
||||||
private static void adjustScaleFromAnchor(ref Vector2 scale, Anchor reference)
|
private static void adjustScaleFromAnchor(ref Vector2 scale, Anchor reference)
|
||||||
{
|
{
|
||||||
// cancel out scale in axes we don't care about (based on which drag handle was used).
|
// cancel out scale in axes we don't care about (based on which drag handle was used).
|
||||||
|
@ -13,6 +13,7 @@ using osu.Framework.Graphics.Sprites;
|
|||||||
using osu.Framework.Graphics.Textures;
|
using osu.Framework.Graphics.Textures;
|
||||||
using osu.Framework.Input.Events;
|
using osu.Framework.Input.Events;
|
||||||
using osu.Framework.Threading;
|
using osu.Framework.Threading;
|
||||||
|
using osu.Framework.Utils;
|
||||||
using osu.Game.Graphics.Containers;
|
using osu.Game.Graphics.Containers;
|
||||||
using osu.Game.Online.API.Requests;
|
using osu.Game.Online.API.Requests;
|
||||||
using osu.Game.Online.API.Requests.Responses;
|
using osu.Game.Online.API.Requests.Responses;
|
||||||
@ -111,7 +112,9 @@ namespace osu.Game.Screens.Menu
|
|||||||
|
|
||||||
content.AddRange(loaded);
|
content.AddRange(loaded);
|
||||||
|
|
||||||
displayIndex = -1;
|
// Many users don't spend much time at the main menu, so let's randomise where in the
|
||||||
|
// carousel of available images we start at to give each a fair chance.
|
||||||
|
displayIndex = RNG.Next(0, images.NewValue.Images.Length) - 1;
|
||||||
showNext();
|
showNext();
|
||||||
}, (cancellationTokenSource ??= new CancellationTokenSource()).Token);
|
}, (cancellationTokenSource ??= new CancellationTokenSource()).Token);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user