Skip to content

SwiftUI views that arrange their children in a flow layout.

License

Notifications You must be signed in to change notification settings

ciaranrobrien/SwiftUIFlow

Repository files navigation

SwiftUI Flow

SwiftUI views that arrange their children in a flow layout.

Demo

HFlow

A view that arranges its children in a horizontal flow.

Usage

ScrollView(.horizontal) {
    HFlow(alignment: .top) {
        //Flow content
    }
}

Parameters

  • alignment: The guide for aligning the subviews in this flow. This guide has the same vertical screen coordinate for every child view.
  • spacing: The distance between adjacent subviews, or nil if you want the flow to choose a default distance for each pair of subviews.
  • content: A view builder that creates the content of this flow.

VFlow

A view that arranges its children in a vertical flow.

Usage

ScrollView(.vertical) {
    VFlow(alignment: .leading) {
        //Flow content
    }
}

Parameters

  • alignment: The guide for aligning the subviews in this flow. This guide has the same horizontal screen coordinate for every child view.
  • spacing: The distance between adjacent subviews, or nil if you want the flow to choose a default distance for each pair of subviews.
  • content: A view builder that creates the content of this flow.

Flow

A view that arranges its children in a flow.

Usage

ScrollView(.vertical) {
    Flow(.vertical, alignment: .topLeading) {
        //Flow content
    }
}

Parameters

  • axis: The layout axis of this flow.
  • alignment: The guide for aligning the subviews in this flow on both the x- and y-axes.
  • spacing: The distance between adjacent subviews, or nil if you want the flow to choose a default distance for each pair of subviews.
  • content: A view builder that creates the content of this flow.

Advanced Usage

The distance between adjacent subviews can be controlled in both axes, by using the horizontalSpacing and verticalSpacing parameters instead of the spacing parameter.

Requirements

  • iOS 14.0+, macOS 11.0+, tvOS 14.0+ or watchOS 7.0+
  • Xcode 12.0+

Installation

Contact

@ciaranrobrien on Twitter.

About

SwiftUI views that arrange their children in a flow layout.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages