Browse Source

Introjucer: made treeview remember its openness state.

tags/2021-05-28
jules 13 years ago
parent
commit
fad59e53d2
6 changed files with 72 additions and 42 deletions
  1. +5
    -0
      extras/Introjucer/Source/Application/jucer_MainWindow.cpp
  2. +21
    -2
      extras/Introjucer/Source/Project/jucer_ProjectContentComponent.cpp
  3. +1
    -0
      extras/Introjucer/Source/Project/jucer_ProjectContentComponent.h
  4. +0
    -2
      extras/Introjucer/Source/Project/jucer_TreeViewTypes.h
  5. +40
    -31
      extras/Introjucer/Source/Utility/jucer_JucerTreeViewBase.cpp
  6. +5
    -7
      extras/Introjucer/Source/Utility/jucer_JucerTreeViewBase.h

+ 5
- 0
extras/Introjucer/Source/Application/jucer_MainWindow.cpp View File

@@ -139,6 +139,11 @@ bool MainWindow::closeProject (Project* project)
if (! OpenDocumentManager::getInstance()->closeAllDocumentsUsingProject (*project, true))
return false;
ProjectContentComponent* const pcc = getProjectContentComponent();
if (pcc != nullptr)
pcc->saveTreeViewState();
FileBasedDocument::SaveResult r = project->saveIfNeededAndUserAgrees();
if (r == FileBasedDocument::savedOk)


+ 21
- 2
extras/Introjucer/Source/Project/jucer_ProjectContentComponent.cpp View File

@@ -59,6 +59,8 @@ void ProjectContentComponent::setProject (Project* newProject)
{
if (project != newProject)
{
PropertiesFile& settings = StoredSettings::getInstance()->getProps();
if (project != nullptr)
project->removeChangeListener (this);
@@ -67,7 +69,7 @@ void ProjectContentComponent::setProject (Project* newProject)
if (projectTree != nullptr)
{
StoredSettings::getInstance()->getProps().setValue ("projectTreeviewWidth", projectTree->getWidth());
settings.setValue ("projectTreeviewWidth", projectTree->getWidth());
projectTree->deleteRootItem();
projectTree = nullptr;
}
@@ -86,7 +88,7 @@ void ProjectContentComponent::setProject (Project* newProject)
projectTree->setRootItem (new GroupTreeViewItem (project->getMainGroup()));
projectTree->getRootItem()->setOpen (true);
String lastTreeWidth (StoredSettings::getInstance()->getProps().getValue ("projectTreeviewWidth"));
String lastTreeWidth (settings.getValue ("projectTreeviewWidth"));
if (lastTreeWidth.getIntValue() < 150)
lastTreeWidth = "250";
@@ -103,10 +105,27 @@ void ProjectContentComponent::setProject (Project* newProject)
invokeDirectly (CommandIDs::showProjectSettings, true);
updateMissingFileStatuses();
const ScopedPointer<XmlElement> treeOpenness (settings.getXmlValue ("treeViewState_" + project->getProjectUID()));
if (treeOpenness != nullptr)
projectTree->restoreOpennessState (*treeOpenness, true);
}
}
}
void ProjectContentComponent::saveTreeViewState()
{
if (projectTree != nullptr)
{
const ScopedPointer<XmlElement> opennessState (projectTree->getOpennessState (true));
if (opennessState != nullptr)
StoredSettings::getInstance()->getProps()
.setValue ("treeViewState_" + project->getProjectUID(), opennessState);
}
}
void ProjectContentComponent::changeListenerCallback (ChangeBroadcaster*)
{
updateMissingFileStatuses();


+ 1
- 0
extras/Introjucer/Source/Project/jucer_ProjectContentComponent.h View File

@@ -45,6 +45,7 @@ public:
void paint (Graphics& g);
void setProject (Project* project);
void saveTreeViewState();
bool showEditorForFile (const File& f);
bool showDocument (OpenDocumentManager::Document* doc);


+ 0
- 2
extras/Introjucer/Source/Project/jucer_TreeViewTypes.h View File

@@ -39,7 +39,6 @@ public:
bool acceptsFileDrop (const StringArray& files) const { return false; }
bool acceptsDragItems (const OwnedArray <Project::Item>& selectedNodes) { return false; }
ProjectTreeViewBase* createSubItem (const Project::Item& child);
void createLeftEdgeComponents (OwnedArray<Component>& components) {}
void showDocument();
void showPopupMenu();
void handlePopupMenuResult (int resultCode);
@@ -60,7 +59,6 @@ public:
void checkFileStatus();
void moveSelectedItemsTo (OwnedArray <Project::Item>& selectedNodes, int insertIndex);
ProjectTreeViewBase* createSubItem (const Project::Item& child);
void createLeftEdgeComponents (OwnedArray<Component>& components) {}
void showDocument();
void showPopupMenu();
void handlePopupMenuResult (int resultCode);


+ 40
- 31
extras/Introjucer/Source/Utility/jucer_JucerTreeViewBase.cpp View File

@@ -28,7 +28,7 @@
//==============================================================================
JucerTreeViewBase::JucerTreeViewBase()
: numLeftHandComps (0)
: textX (0)
{
setLinesDrawnForSubItems (false);
}
@@ -38,26 +38,10 @@ Font JucerTreeViewBase::getFont() const
return Font (getItemHeight() * 0.6f);
}
int JucerTreeViewBase::getTextX() const
{
return (numLeftHandComps + 1) * getItemHeight() + 8;
}
void JucerTreeViewBase::paintItem (Graphics& g, int width, int height)
{
if (isSelected())
g.fillAll (Colour (0x401111ee));
const int x = getTextX();
g.setColour (Colours::black);
getIcon()->drawWithin (g, Rectangle<float> (0.0f, 2.0f, height + 6.0f, height - 4.0f),
RectanglePlacement::centred | RectanglePlacement::onlyReduceInSize, 1.0f);
g.setFont (getFont());
g.setColour (isMissing() ? Colours::red : Colours::black);
g.drawFittedText (getDisplayName(), x, 0, width - x, height, Justification::centredLeft, 1, 0.8f);
}
void JucerTreeViewBase::paintOpenCloseButton (Graphics& g, int width, int height, bool isMouseOver)
@@ -74,38 +58,63 @@ void JucerTreeViewBase::paintOpenCloseButton (Graphics& g, int width, int height
}
//==============================================================================
class TreeLeftHandButtonHolderComponent : public Component
class TreeItemComponent : public Component
{
public:
TreeLeftHandButtonHolderComponent (OwnedArray<Component>& comps)
TreeItemComponent (JucerTreeViewBase& item_)
: item (item_)
{
components.swapWithArray (comps);
setInterceptsMouseClicks (false, true);
for (int i = 0; i < components.size(); ++i)
addAndMakeVisible (components.getUnchecked(i));
item.createLeftEdgeComponents (leftComps);
for (int i = 0; i < leftComps.size(); ++i)
addAndMakeVisible (leftComps.getUnchecked(i));
addAndMakeVisible (rightHandComponent = item.createRightEdgeComponent());
}
void paint (Graphics& g)
{
g.setColour (Colours::black);
const int height = getHeight();
item.getIcon()->drawWithin (g, Rectangle<float> (0.0f, 2.0f, height + 6.0f, height - 4.0f),
RectanglePlacement::centred | RectanglePlacement::onlyReduceInSize, 1.0f);
g.setFont (item.getFont());
g.setColour (item.isMissing() ? Colours::red : Colours::black);
const int right = rightHandComponent != nullptr ? rightHandComponent->getX() - 2
: getWidth();
g.drawFittedText (item.getDisplayName(),
item.textX, 0, right - item.textX, height, Justification::centredLeft, 1, 0.8f);
}
void resized()
{
const int edge = 1;
const int itemSize = getHeight() - edge * 2;
item.textX = (leftComps.size() + 1) * getHeight() + 8;
for (int i = 0; i < leftComps.size(); ++i)
leftComps.getUnchecked(i)->setBounds (5 + (i + 1) * getHeight(), edge, itemSize, itemSize);
for (int i = 0; i < components.size(); ++i)
components.getUnchecked(i)->setBounds (5 + (i + 1) * getHeight(), edge, itemSize, itemSize);
if (rightHandComponent != nullptr)
rightHandComponent->setBounds (getWidth() - itemSize - edge, edge, itemSize, itemSize);
}
private:
OwnedArray<Component> components;
JucerTreeViewBase& item;
OwnedArray<Component> leftComps;
ScopedPointer<Component> rightHandComponent;
};
Component* JucerTreeViewBase::createItemComponent()
{
OwnedArray<Component> components;
createLeftEdgeComponents (components);
numLeftHandComps = components.size();
return numLeftHandComps == 0 ? nullptr : new TreeLeftHandButtonHolderComponent (components);
return new TreeItemComponent (*this);
}
//==============================================================================
@@ -149,7 +158,7 @@ private:
void JucerTreeViewBase::showRenameBox()
{
Rectangle<int> r (getItemPosition (true));
r.setLeft (r.getX() + getTextX());
r.setLeft (r.getX() + textX);
r.setHeight (getItemHeight());
new RenameTreeItemCallback (*this, *getOwnerView(), r);


+ 5
- 7
extras/Introjucer/Source/Utility/jucer_JucerTreeViewBase.h View File

@@ -33,6 +33,8 @@
class JucerTreeViewBase : public TreeViewItem
{
public:
JucerTreeViewBase();
int getItemWidth() const { return -1; }
int getItemHeight() const { return 20; }
@@ -48,7 +50,8 @@ public:
virtual void setName (const String& newName) = 0;
virtual bool isMissing() = 0;
virtual const Drawable* getIcon() const = 0;
virtual void createLeftEdgeComponents (OwnedArray<Component>& components) = 0;
virtual void createLeftEdgeComponents (OwnedArray<Component>&) {}
virtual Component* createRightEdgeComponent() { return nullptr; }
virtual void showPopupMenu();
virtual void showMultiSelectionPopupMenu();
@@ -72,12 +75,7 @@ public:
}
};
protected:
JucerTreeViewBase();
private:
int numLeftHandComps;
int getTextX() const;
int textX;
};


Loading…
Cancel
Save