Last Update: 29/December/2019.
If you like the project, please give it a star β It will show the creator your appreciation and help others to discover the repo.
π Column Text View is an adaptive UI component that renders text in columns, horizontally [iOS 12, UIKit, TextKit, SwiftUI].
Please wait while the .gif
files are loading...
- Configurable
- There are a number of configurable properties and you can use, such as, you can specify the number of columns for the supplied text, specify column spacing, paddings and other properties
- Adaptive
- The underlying text container adjusts its size to support the needed amount of space for the supplied text
- SwiftUI Compatable
- You can use a dedicated wrapper called
ColumnedTextView
to use the componet withSwiftUI
- You can use a dedicated wrapper called
- Ease of Use
- Instantiate a single instane of
ColumnTextView
orColumnedTextView
(forSwiftUI
), setup the parent view and supply some text
- Instantiate a single instane of
- Designable and Inspectable
- You can use
.storyboard
or.xib
files to configure the component without touching code (well, almost)
- You can use
The first thing you need to do is to prepare the UI component. The following example demostrates the programmatic approach, where the component is instantiated without .storyboard
or .xib
outlets:
// 1
let columnTextView = ColumnTextView(frame: view.bounds, .columns(2))
columnTextView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
columnTextView.backgroundColor = .white
parentView.addSubview(columnTextView)
// 2
columnTextView.attributedText = attributedString
- (1) The first part is instantiation and setup. Here we have pretty usual things happenning, nothing exotic π΄. You can specify the way the columns should be created. Here you have two options: to use
.absolute(***UInt16***)
, where the associated parameter is a single columnwidth
in points or to use.columns(***UInt16***)
, where the associated parameter is a positive integer number that specifies the exact number of columns that should be created for the current screen'swidth
. - (2) The next part is about the text
attachment
. You simply create an instance ofNSAttributedString
, configure it as you'd like and that's it.
You can change the attributedText
property, the results will be correspondigly reflected and specify all four
paddings for top, right, bottom and left
sides of the component.
- Open
MenuBar
βFile
βSwift Packages
βAdd Package Dependency...
- Paste the package repository url
https://github.com/jVirus/column-text-view-ui
and hitNext
. - Select the installment rules.
After specifying which version do you want to install, the package will be downloaded and attached to your project.
If you already have a Package.swift
or you are building your own package simply add a new dependency:
dependencies: [
.package(url: "`https://github.com/jVirus/column-text-view-ui", from: "1.0.0")
]
You can always use copy-paste the sources method π. Or you can compile the framework and include it with your project.
Your contributions are always appreciated. There are many ways how you help with the project:
- You can suggest something
- You can write additional documentation or sample codes
- Implement a new feature
- Fix a bug
- Help to maintain by answering to the questions (if any) that other folks have
- etc.
Overall guidelies are:
- Please, discuss a feature or a major source change/addition before spending time and creating a pool requested via issues.
- Create a separate branch and make sure that your code compiles and does not produce errors and warnings.
- Please, don't be upset if it takes a while to review your code or receive an answer.
The project is available under MIT Licence