Skip to content

Commit

Permalink
Merge branch 'develop-github' into uiscripting-github
Browse files Browse the repository at this point in the history
# Conflicts:
#	vstgui/lib/cgraphicspath.h
  • Loading branch information
scheffle committed Jul 9, 2024
2 parents 43d31b4 + 07ca495 commit 9ea5a6e
Show file tree
Hide file tree
Showing 34 changed files with 918 additions and 118 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/cmake_linux.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ jobs:
os: [ubuntu-20.04, ubuntu-22.04]

steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4

- run: sudo apt-get update
- run: sudo apt-get install libx11-dev libx11-xcb-dev libxcb-util-dev libxcb-cursor-dev libxcb-keysyms1-dev libxcb-xkb-dev libxkbcommon-dev libxkbcommon-x11-dev libfontconfig1-dev libcairo2-dev libfreetype6-dev libpango1.0-dev
Expand Down
4 changes: 2 additions & 2 deletions .github/workflows/cmake_macos.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,10 @@ jobs:

strategy:
matrix:
os: [macos-11, macos-12]
os: [macos-11, macos-13]

steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4

- uses: ./.github/actions/cmake
with:
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/cmake_windows.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ jobs:
os: [windows-2019, windows-2022]

steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4

- uses: ./.github/actions/cmake
with:
Expand Down
21 changes: 20 additions & 1 deletion vstgui/contrib/externalview_nsview.h
Original file line number Diff line number Diff line change
Expand Up @@ -152,7 +152,26 @@ struct ExternalNSViewBase : ViewAdapter

ExternalNSViewBase (ViewType* inView) : view (inView)
{
container.clipsToBounds = YES;
if (@available (macOS 14, *))
{
#ifdef MAC_OS_VERSION_14_0
// only available when building with the mac os sdk 14.0
container.clipsToBounds = YES;
#else
// but necessary to set to YES on macOS 14 even when not building with Xcode 15
if ([container respondsToSelector:@selector (setClipsToBounds:)])
{
BOOL clipsToBounds = YES;
auto* signature = [[container class]
instanceMethodSignatureForSelector:@selector (setClipsToBounds:)];
auto* invocation = [NSInvocation invocationWithMethodSignature:signature];
invocation.target = container;
invocation.selector = @selector (setClipsToBounds:);
[invocation setArgument:&clipsToBounds atIndex:2];
[invocation invoke];
}
#endif
}
[container addSubview:view];
}

Expand Down
1 change: 1 addition & 0 deletions vstgui/doxygen/page_changes.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ It's recommended to start new projects with version 4 while old projects should
- add crosshair mouse cursor (kCursorCrosshair)
- customizable knob range (see CKnob::setKnobRange)
- new layouts for CRowColumnView
@subsection version4_13 Version 4.13
Expand Down
2 changes: 1 addition & 1 deletion vstgui/lib/cdrawcontext.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -742,7 +742,7 @@ bool CDrawContext::drawLinearGradientLine (const DrawLinearGradientLineCallback&
CGraphicsPath* CDrawContext::createGraphicsPath ()
{
if (impl->device)
return new CGraphicsPath (impl->device->getGraphicsPathFactory ());
return new CGraphicsPath (impl->device->getGraphicsPathFactory (), nullptr);
return nullptr;
}

Expand Down
8 changes: 8 additions & 0 deletions vstgui/lib/controls/coptionmenu.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -888,6 +888,14 @@ void COptionMenu::setValue (float val)
setDirty ();
}

//------------------------------------------------------------------------
float COptionMenu::getMax () const
{
if (menuItems->empty ())
return 0.f;
return static_cast<float> (menuItems->size () - 1);
}

//------------------------------------------------------------------------
void COptionMenu::takeFocus ()
{
Expand Down
2 changes: 1 addition & 1 deletion vstgui/lib/controls/coptionmenu.h
Original file line number Diff line number Diff line change
Expand Up @@ -307,7 +307,7 @@ class COptionMenu : public CParamDisplay
void setMin (float val) override {}
float getMin () const override { return 0; }
void setMax (float val) override {}
float getMax () const override { return (float)(menuItems->size () - 1); }
float getMax () const override;

void draw (CDrawContext* pContext) override;
CMouseEventResult onMouseDown (CPoint& where, const CButtonState& buttons) override;
Expand Down
238 changes: 238 additions & 0 deletions vstgui/lib/crowcolumnview.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,229 @@
#include "crowcolumnview.h"
#include "animation/animations.h"
#include "animation/timingfunctions.h"
#include <vector>

namespace VSTGUI {
namespace Layouting {
//--------------------------------------------------------------------------------
using CRects = std::vector<CRect>;

enum class Alignment
{
kTopLeft,
kTopCenter,
kTopRight,
kMiddleLeft,
kMiddleCenter,
kMiddleRight,
kBottomLeft,
kBottomCenter,
kBottomRight
};

enum class Style
{
kRow,
kColumn
};

//--------------------------------------------------------------------------------
Alignment translate (const CRowColumnView::LayoutStyle layoutStyle)
{
switch (layoutStyle)
{
case CRowColumnView::LayoutStyle::kTopLeft:
return Alignment::kTopLeft;
case CRowColumnView::LayoutStyle::kTopCenter:
return Alignment::kTopCenter;
case CRowColumnView::LayoutStyle::kTopRight:
return Alignment::kTopRight;
case CRowColumnView::LayoutStyle::kMiddleLeft:
return Alignment::kMiddleLeft;
case CRowColumnView::LayoutStyle::kMiddleCenter:
return Alignment::kMiddleCenter;
case CRowColumnView::LayoutStyle::kMiddleRight:
return Alignment::kMiddleRight;
case CRowColumnView::LayoutStyle::kBottomLeft:
return Alignment::kBottomLeft;
case CRowColumnView::LayoutStyle::kBottomCenter:
return Alignment::kBottomCenter;
case CRowColumnView::LayoutStyle::kBottomRight:
return Alignment::kBottomRight;
default:
return Alignment::kTopLeft;
}
}

//--------------------------------------------------------------------------------
Style translate (const CRowColumnView::Style style)
{
switch (style)
{
case CRowColumnView::Style::kRowStyle:
return Style::kRow;
case CRowColumnView::Style::kColumnStyle:
return Style::kColumn;
default:
return Style::kRow;
}
}

//--------------------------------------------------------------------------------
CPoint computeRectOffset (const CPoint& parent, const CPoint& rect, const Alignment alignment)
{
CPoint offset (0., 0.);
switch (alignment)
{
case Alignment::kTopLeft:
{
offset = CPoint (0., 0.);
break;
}
case Alignment::kTopCenter:
{
offset = CPoint ((parent.x - rect.x) / 2., 0.);
break;
}
case Alignment::kTopRight:
{
offset = CPoint (parent.x - rect.x, 0.);
break;
}
case Alignment::kMiddleLeft:
{
offset = CPoint (0., (parent.y - rect.y) / 2.);
break;
}
case Alignment::kMiddleCenter:
{
offset = CPoint ((parent.x - rect.x) / 2., (parent.y - rect.y) / 2.);
break;
}
case Alignment::kMiddleRight:
{
offset = CPoint (parent.x - rect.x, (parent.y - rect.y) / 2.);
break;
}
case Alignment::kBottomLeft:
{
offset = CPoint (0., parent.y - rect.y);
break;
}
case Alignment::kBottomCenter:
{
offset = CPoint ((parent.x - rect.x) / 2., parent.y - rect.y);
break;
}
case Alignment::kBottomRight:
{
offset = CPoint (parent.x - rect.x, parent.y - rect.y);
break;
}
default:
break;
}

return offset;
}

//--------------------------------------------------------------------------------
CRect computeGroupRect (const CRect& parent, const CRects& children, const Alignment alignment,
const Style style, double spacing)
{
CPoint maxSize;
if (style == Style::kRow)
{
for (const auto& rect : children)
{
if (maxSize.x < rect.getWidth ())
maxSize.x = rect.getWidth ();

maxSize.y = maxSize.y + rect.getHeight () + spacing;
}

// Remove the last spacing again
if (!children.empty())
maxSize.y -= spacing;
}
else
{
for (const auto& rect : children)
{
if (maxSize.y < rect.getHeight ())
maxSize.y = rect.getHeight ();

maxSize.x = maxSize.x + rect.getWidth () + spacing;
}

// Remove the last spacing again
if (!children.empty())
maxSize.x -= spacing;
}

const auto offset = computeRectOffset (parent.getSize (), maxSize, alignment);
return CRect().setSize(maxSize).offset(offset);
}

//--------------------------------------------------------------------------------
CRect computeGroupRect (const CViewContainer& parent, const Alignment alignment, const Style style,
const double spacing)
{
CRects childrenViewSizes;
parent.forEachChild (
[&] (const CView* child) { childrenViewSizes.push_back (child->getViewSize ()); });

return computeGroupRect (parent.getViewSize (), childrenViewSizes, alignment, style, spacing);
}

//--------------------------------------------------------------------------------
// AutoLayout Declaration
/// @brief An auto layout feature for the CRowColumnView
///
/// The AutoLayout flexibly layouts the children of a CRowColumnView. The children are grouped and
/// aligned among themselves depending on whether the style is a row (left to right) or a
/// column (top to bottom). The group is moved inside the parent to either of the nine
/// positions (top-left, top-center, top-right, middle-left, middle-center, middle-right,
/// bottom-left, bottom-center or bottom-right). If the size of the parent is changed, the layout
/// and alignment of the group is always retained.
//--------------------------------------------------------------------------------
class AutoLayout
{
public:
//--------------------------------------------------------------------------------
AutoLayout (const CViewContainer& parent, const Alignment alignment, const Style style,
const double spacing)
: alignment (alignment), style (style)
{
groupRect = Layouting::computeGroupRect (parent, alignment, style, spacing);
}

/** moves the child rect to the calculated position (inside the group and inside the parent) */
auto moveRect (CRect& viewSize) -> CRect&
{
// Offset the viewSize inside the groupRect...
const CPoint offset =
Layouting::computeRectOffset (groupRect.getSize (), viewSize.getSize (), alignment);
if (style == Style::kRow)
viewSize.offset (offset.x, 0.);
else
viewSize.offset (0., offset.y);

//...and offset by topLeft of the groupRect afterwards, in order to align with the
// 'real' parent.
return viewSize.offset (groupRect.getTopLeft ());
}

//--------------------------------------------------------------------------------
private:
const Alignment alignment = Alignment::kTopLeft;
const Style style = Style::kRow;
CRect groupRect;
};

//--------------------------------------------------------------------------------

}

//--------------------------------------------------------------------------------
CRowColumnView::CRowColumnView (const CRect& size, Style style, LayoutStyle layoutStyle, CCoord spacing, const CRect& margin)
Expand Down Expand Up @@ -127,6 +348,10 @@ void CRowColumnView::layoutViewsEqualSize ()
maxSize.x = getViewSize ().getWidth () - (margin.right + margin.left);
else
maxSize.y = getViewSize ().getHeight () - (margin.top + margin.bottom);

Layouting::AutoLayout layout (*this, Layouting::translate (layoutStyle),
Layouting::translate (style), spacing);

CPoint location = margin.getTopLeft ();
forEachChild ([&] (CView* view) {
CRect viewSize = view->getViewSize ();
Expand Down Expand Up @@ -154,6 +379,19 @@ void CRowColumnView::layoutViewsEqualSize ()
viewSize.offset (diffX, diffY);
break;
}
case kTopLeft:
case kTopCenter:
case kTopRight:
case kMiddleLeft:
case kMiddleCenter:
case kMiddleRight:
case kBottomLeft:
case kBottomCenter:
case kBottomRight:
{
layout.moveRect (viewSize);
break;
}
default:
break;
}
Expand Down
13 changes: 12 additions & 1 deletion vstgui/lib/crowcolumnview.h
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,18 @@ class CRowColumnView : public CAutoLayoutContainerView
/** subviews have the same right or bottom position */
kRightBottomEqualy,
/** stretch subviews to the same width and height */
kStretchEqualy
kStretchEqualy,

/** options for the auto layout feature */
kTopLeft,
kTopCenter,
kTopRight,
kMiddleLeft,
kMiddleCenter,
kMiddleRight,
kBottomLeft,
kBottomCenter,
kBottomRight
};

CRowColumnView (const CRect& size, Style style = kRowStyle, LayoutStyle layoutStyle = kLeftTopEqualy, CCoord spacing = 0., const CRect& margin = CRect (0., 0., 0., 0.));
Expand Down
Loading

0 comments on commit 9ea5a6e

Please sign in to comment.