mirror of
https://github.com/aseprite/aseprite.git
synced 2025-02-21 21:41:02 +00:00
Add command to open/close layer groups (Shift+E)
This commit is contained in:
parent
042b427f49
commit
e2595f3cce
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!-- Aseprite -->
|
<!-- Aseprite -->
|
||||||
<!-- Copyright (C) 2001-2016 by David Capello -->
|
<!-- Copyright (C) 2001-2017 by David Capello -->
|
||||||
<gui version="1.2-dev">
|
<gui version="1.2-dev">
|
||||||
<!-- Keyboard shortcuts -->
|
<!-- Keyboard shortcuts -->
|
||||||
<keyboard version="1">
|
<keyboard version="1">
|
||||||
@ -61,6 +61,7 @@
|
|||||||
<!-- Layer -->
|
<!-- Layer -->
|
||||||
<key command="LayerProperties" shortcut="Shift+P" />
|
<key command="LayerProperties" shortcut="Shift+P" />
|
||||||
<key command="LayerVisibility" shortcut="Shift+X" />
|
<key command="LayerVisibility" shortcut="Shift+X" />
|
||||||
|
<key command="OpenGroup" shortcut="Shift+E" />
|
||||||
<key command="NewLayer" shortcut="Shift+N" />
|
<key command="NewLayer" shortcut="Shift+N" />
|
||||||
<key command="NewLayer" shortcut="Alt+Shift+N">
|
<key command="NewLayer" shortcut="Alt+Shift+N">
|
||||||
<param name="group" value="true" />
|
<param name="group" value="true" />
|
||||||
@ -679,6 +680,7 @@
|
|||||||
<menu text="&Layer">
|
<menu text="&Layer">
|
||||||
<item command="LayerProperties" text="&Properties..." />
|
<item command="LayerProperties" text="&Properties..." />
|
||||||
<item command="LayerVisibility" text="&Visible" />
|
<item command="LayerVisibility" text="&Visible" />
|
||||||
|
<item command="OpenGroup" text="&Open Group" />
|
||||||
<separator />
|
<separator />
|
||||||
<item command="NewLayer" text="&New Layer" />
|
<item command="NewLayer" text="&New Layer" />
|
||||||
<item command="NewLayer" text="New &Group">
|
<item command="NewLayer" text="New &Group">
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# Aseprite
|
# Aseprite
|
||||||
# Copyright (C) 2001-2016 David Capello
|
# Copyright (C) 2001-2017 David Capello
|
||||||
|
|
||||||
# Generate a ui::Widget for each widget in a XML file
|
# Generate a ui::Widget for each widget in a XML file
|
||||||
file(GLOB widget_files ${CMAKE_SOURCE_DIR}/data/widgets/*.xml)
|
file(GLOB widget_files ${CMAKE_SOURCE_DIR}/data/widgets/*.xml)
|
||||||
@ -257,6 +257,7 @@ add_library(app-lib
|
|||||||
commands/cmd_onionskin.cpp
|
commands/cmd_onionskin.cpp
|
||||||
commands/cmd_open_browser.cpp
|
commands/cmd_open_browser.cpp
|
||||||
commands/cmd_open_file.cpp
|
commands/cmd_open_file.cpp
|
||||||
|
commands/cmd_open_group.cpp
|
||||||
commands/cmd_open_in_folder.cpp
|
commands/cmd_open_in_folder.cpp
|
||||||
commands/cmd_open_with_app.cpp
|
commands/cmd_open_with_app.cpp
|
||||||
commands/cmd_options.cpp
|
commands/cmd_options.cpp
|
||||||
|
71
src/app/commands/cmd_open_group.cpp
Normal file
71
src/app/commands/cmd_open_group.cpp
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
// Aseprite
|
||||||
|
// Copyright (C) 2017 David Capello
|
||||||
|
//
|
||||||
|
// This program is distributed under the terms of
|
||||||
|
// the End-User License Agreement for Aseprite.
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
#include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "app/commands/command.h"
|
||||||
|
#include "app/context_access.h"
|
||||||
|
#include "app/modules/gui.h"
|
||||||
|
#include "doc/layer.h"
|
||||||
|
|
||||||
|
namespace app {
|
||||||
|
|
||||||
|
using namespace ui;
|
||||||
|
|
||||||
|
class OpenGroupCommand : public Command {
|
||||||
|
public:
|
||||||
|
OpenGroupCommand();
|
||||||
|
Command* clone() const override { return new OpenGroupCommand(*this); }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
bool onEnabled(Context* context) override;
|
||||||
|
bool onChecked(Context* context) override;
|
||||||
|
void onExecute(Context* context) override;
|
||||||
|
|
||||||
|
// TODO onGetFriendlyName() needs the Context so we can return "Open
|
||||||
|
// Group" or "Close Group" depending on the context
|
||||||
|
//std::string onGetFriendlyName() const override;
|
||||||
|
};
|
||||||
|
|
||||||
|
OpenGroupCommand::OpenGroupCommand()
|
||||||
|
: Command("OpenGroup",
|
||||||
|
"Open/Close Group",
|
||||||
|
CmdRecordableFlag)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
bool OpenGroupCommand::onEnabled(Context* context)
|
||||||
|
{
|
||||||
|
const ContextReader reader(context);
|
||||||
|
const Layer* layer = reader.layer();
|
||||||
|
return (layer && layer->isGroup());
|
||||||
|
}
|
||||||
|
|
||||||
|
bool OpenGroupCommand::onChecked(Context* context)
|
||||||
|
{
|
||||||
|
const ContextReader reader(context);
|
||||||
|
const Layer* layer = reader.layer();
|
||||||
|
return (layer && layer->isExpanded());
|
||||||
|
}
|
||||||
|
|
||||||
|
void OpenGroupCommand::onExecute(Context* context)
|
||||||
|
{
|
||||||
|
ContextWriter writer(context);
|
||||||
|
Layer* layer = writer.layer();
|
||||||
|
|
||||||
|
layer->setCollapsed(layer->isExpanded());
|
||||||
|
|
||||||
|
update_screen_for_document(writer.document());
|
||||||
|
}
|
||||||
|
|
||||||
|
Command* CommandFactory::createOpenGroupCommand()
|
||||||
|
{
|
||||||
|
return new OpenGroupCommand;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace app
|
@ -1,5 +1,5 @@
|
|||||||
// Aseprite
|
// Aseprite
|
||||||
// Copyright (C) 2001-2016 David Capello
|
// Copyright (C) 2001-2017 David Capello
|
||||||
//
|
//
|
||||||
// This program is distributed under the terms of
|
// This program is distributed under the terms of
|
||||||
// the End-User License Agreement for Aseprite.
|
// the End-User License Agreement for Aseprite.
|
||||||
@ -82,6 +82,7 @@ FOR_EACH_COMMAND(NewLayer)
|
|||||||
FOR_EACH_COMMAND(NewSpriteFromSelection)
|
FOR_EACH_COMMAND(NewSpriteFromSelection)
|
||||||
FOR_EACH_COMMAND(OpenBrowser)
|
FOR_EACH_COMMAND(OpenBrowser)
|
||||||
FOR_EACH_COMMAND(OpenFile)
|
FOR_EACH_COMMAND(OpenFile)
|
||||||
|
FOR_EACH_COMMAND(OpenGroup)
|
||||||
FOR_EACH_COMMAND(OpenInFolder)
|
FOR_EACH_COMMAND(OpenInFolder)
|
||||||
FOR_EACH_COMMAND(OpenWithApp)
|
FOR_EACH_COMMAND(OpenWithApp)
|
||||||
FOR_EACH_COMMAND(Options)
|
FOR_EACH_COMMAND(Options)
|
||||||
@ -121,7 +122,6 @@ FOR_EACH_COMMAND(ShowExtras)
|
|||||||
FOR_EACH_COMMAND(ShowGrid)
|
FOR_EACH_COMMAND(ShowGrid)
|
||||||
FOR_EACH_COMMAND(ShowLayerEdges)
|
FOR_EACH_COMMAND(ShowLayerEdges)
|
||||||
FOR_EACH_COMMAND(ShowOnionSkin)
|
FOR_EACH_COMMAND(ShowOnionSkin)
|
||||||
FOR_EACH_COMMAND(ToggleTimelineThumbnails)
|
|
||||||
FOR_EACH_COMMAND(ShowPixelGrid)
|
FOR_EACH_COMMAND(ShowPixelGrid)
|
||||||
FOR_EACH_COMMAND(ShowSelectionEdges)
|
FOR_EACH_COMMAND(ShowSelectionEdges)
|
||||||
FOR_EACH_COMMAND(SnapToGrid)
|
FOR_EACH_COMMAND(SnapToGrid)
|
||||||
@ -132,6 +132,7 @@ FOR_EACH_COMMAND(SymmetryMode)
|
|||||||
FOR_EACH_COMMAND(TiledMode)
|
FOR_EACH_COMMAND(TiledMode)
|
||||||
FOR_EACH_COMMAND(Timeline)
|
FOR_EACH_COMMAND(Timeline)
|
||||||
FOR_EACH_COMMAND(TogglePreview)
|
FOR_EACH_COMMAND(TogglePreview)
|
||||||
|
FOR_EACH_COMMAND(ToggleTimelineThumbnails)
|
||||||
FOR_EACH_COMMAND(Undo)
|
FOR_EACH_COMMAND(Undo)
|
||||||
FOR_EACH_COMMAND(UndoHistory)
|
FOR_EACH_COMMAND(UndoHistory)
|
||||||
FOR_EACH_COMMAND(UnlinkCel)
|
FOR_EACH_COMMAND(UnlinkCel)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user