mirror of
https://github.com/osukey/osukey.git
synced 2025-08-07 00:23:59 +09:00
Merge pull request #14017 from frenzibyte/room-eating-drag
Fix rooms in online-play longue screen no longer scrollable by dragging
This commit is contained in:
@ -10,6 +10,7 @@ using osu.Game.Screens.OnlinePlay.Lounge;
|
|||||||
using osu.Game.Screens.OnlinePlay.Lounge.Components;
|
using osu.Game.Screens.OnlinePlay.Lounge.Components;
|
||||||
using osu.Game.Screens.OnlinePlay.Playlists;
|
using osu.Game.Screens.OnlinePlay.Playlists;
|
||||||
using osu.Game.Tests.Visual.OnlinePlay;
|
using osu.Game.Tests.Visual.OnlinePlay;
|
||||||
|
using osuTK.Input;
|
||||||
|
|
||||||
namespace osu.Game.Tests.Visual.Playlists
|
namespace osu.Game.Tests.Visual.Playlists
|
||||||
{
|
{
|
||||||
@ -30,17 +31,35 @@ namespace osu.Game.Tests.Visual.Playlists
|
|||||||
|
|
||||||
private RoomsContainer roomsContainer => loungeScreen.ChildrenOfType<RoomsContainer>().First();
|
private RoomsContainer roomsContainer => loungeScreen.ChildrenOfType<RoomsContainer>().First();
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestScrollByDraggingRooms()
|
||||||
|
{
|
||||||
|
AddStep("reset mouse", () => InputManager.ReleaseButton(MouseButton.Left));
|
||||||
|
|
||||||
|
AddStep("add rooms", () => RoomManager.AddRooms(30));
|
||||||
|
|
||||||
|
AddUntilStep("first room is not masked", () => checkRoomVisible(roomsContainer.Rooms[0]));
|
||||||
|
|
||||||
|
AddStep("move mouse to third room", () => InputManager.MoveMouseTo(roomsContainer.Rooms[2]));
|
||||||
|
AddStep("hold down", () => InputManager.PressButton(MouseButton.Left));
|
||||||
|
AddStep("drag to top", () => InputManager.MoveMouseTo(roomsContainer.Rooms[0]));
|
||||||
|
|
||||||
|
AddAssert("first and second room masked", ()
|
||||||
|
=> !checkRoomVisible(roomsContainer.Rooms[0]) &&
|
||||||
|
!checkRoomVisible(roomsContainer.Rooms[1]));
|
||||||
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestScrollSelectedIntoView()
|
public void TestScrollSelectedIntoView()
|
||||||
{
|
{
|
||||||
AddStep("add rooms", () => RoomManager.AddRooms(30));
|
AddStep("add rooms", () => RoomManager.AddRooms(30));
|
||||||
|
|
||||||
AddUntilStep("first room is not masked", () => checkRoomVisible(roomsContainer.Rooms.First()));
|
AddUntilStep("first room is not masked", () => checkRoomVisible(roomsContainer.Rooms[0]));
|
||||||
|
|
||||||
AddStep("select last room", () => roomsContainer.Rooms.Last().Click());
|
AddStep("select last room", () => roomsContainer.Rooms[^1].Click());
|
||||||
|
|
||||||
AddUntilStep("first room is masked", () => !checkRoomVisible(roomsContainer.Rooms.First()));
|
AddUntilStep("first room is masked", () => !checkRoomVisible(roomsContainer.Rooms[0]));
|
||||||
AddUntilStep("last room is not masked", () => checkRoomVisible(roomsContainer.Rooms.Last()));
|
AddUntilStep("last room is not masked", () => checkRoomVisible(roomsContainer.Rooms[^1]));
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool checkRoomVisible(DrawableRoom room) =>
|
private bool checkRoomVisible(DrawableRoom room) =>
|
||||||
|
@ -275,14 +275,6 @@ namespace osu.Game.Screens.OnlinePlay.Lounge.Components
|
|||||||
|
|
||||||
protected override bool ShouldBeConsideredForInput(Drawable child) => state == SelectionState.Selected;
|
protected override bool ShouldBeConsideredForInput(Drawable child) => state == SelectionState.Selected;
|
||||||
|
|
||||||
protected override bool OnMouseDown(MouseDownEvent e)
|
|
||||||
{
|
|
||||||
if (selectedRoom.Value != Room)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
return base.OnMouseDown(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override bool OnClick(ClickEvent e)
|
protected override bool OnClick(ClickEvent e)
|
||||||
{
|
{
|
||||||
if (Room != selectedRoom.Value)
|
if (Room != selectedRoom.Value)
|
||||||
|
Reference in New Issue
Block a user