Pixate Freestyle is a toolkit for styling native mobile applications. It consists of a comprehensive collection of CSS classes that work with the Pixate Framework to provide an easily customized base of styles for applications. Think of it as Bootstrap for native apps. Currently, it only supports iOS 7. Android support is coming soon.
Getting started with Freestyle is easy. You need to install the Pixate Framework, add the Freestyle CSS or Sass files to your project, and apply the Freestyle classes to views and controls in your app.
The Pixate Framework lets you style your native iOS applications with stylesheets. If you aren't already familiar with Pixate, check out the Getting Started guide to familiarize yourself with how it works. You can install it in three ways:
- Download directly from Pixate. Freestyle is already packed in this download.
- Install using CocoaPods (spec name is 'Pixate').
- Clone the Pixate Framework repo
git clone [email protected]:Pixate/PixateFramework.git
.
You can also clone the Freestyle repo and use the Showcase app as a starter app, which already has the latest release of Pixate installed. Note that the Showcase uses the Freestyle CSS file, so you can try it out without installing Sass. If you want to play around with variables and such, you'll need to follow the instructions below for compiling the Sass files.
Once you have the framework, follow the Getting Started guide to set up the framework in your application. Note that you will need Pixate 2.0.1 or greater for Freestyle to work properly. Also, the Pixate Framework now includes Freestyle, so you won't need to download Freestyle separately.
You can grab Freestyle two ways:
- Download the latest release.
- Clone this repo
git clone [email protected]:Pixate/Freestyle.git
.
Note the Freestyle currently only contains styles for apps targeting iOS 7. You can certainly add your own styles for iOS 6.
Once you've downloaded and installed Pixate and downloaded Freestyle, you have two options to add Freestyle to your project:
- Add the default.css file from the Freestyle repo to your project. This contains all of the styles, but will be harder to customize as it is not modular.
- Add the Sass files to your project. You will need to set up the Sass precompiler - see the 'Compiling Sass' section below. This option makes it a lot easier to customize the styles, since it's completely modular.
Once the CSS or SCSS files are added, you can apply the classes to any relevant view or control by adding a styleClass
runtime attribute in Interface Builder to the view or control, or importing Pixate/Pixate.h
in your view controller and setting the styleClass
property (e.g. myButton.styleClass = @"button small";
. The Pixate Getting Started guide has more details on setting classes.
Freestyle/
├── css/
│ └── default.css
├── scss/
│ ├── default.scss
│ ├── base.scss
│ ├── buttons.scss
│ ├── collections.scss
│ ├── forms.scss
│ ├── icons.scss
│ ├── tables.scss
│ ├── type.scss
│ └── variables.scss
└── PixateFreestyleShowcase/
├── PixateFreestyleShowcase/
├── PixateFreestyleShowcaseTests
└── PixateFreestyleShowcase.xcodeproj
Included in Freestyle are several Sass files that, once compiled, generate the Freestyle CSS that will be used by the Pixate Framework. Sass allows Freestyle to be modular. You can modify variables to theme the default styles, or edit any part of the Sass to your heart's content.
You can simply grab the compiled CSS file from this repo and add it to your project (see Getting Started), or you can follow these simple steps to compile the .scss files. Once you've installed Pixate and added the Freestyle Sass files to your application, do the following:
- Install Sass - this requires Ruby, which you should already have if you're running OS X.
- If you already added the Freestyle default.css file to your project, remove it (it will be replaced by the compiled Sass files).
- Add all of the files in Freestyle/scss to your project in Xcode.
- In XCode, click on your project in the Project Navigator.
- Click on the
Build Phases
tab. - From the top menu under
Editor
, selectAdd Build Phase
, thenAdd Build Script Run Phase
. - In the new Run Script field enter:
source /Users/${USER}/.rvm/environments/default
${GEM_HOME}/bin/sass ${TARGET_BUILD_DIR}/${CONTENTS_FOLDER_PATH}/default.scss ${TARGET_BUILD_DIR}/${CONTENTS_FOLDER_PATH}/default.css
- Do not put anything under
Input Files
orOutput Files
Now, when you build your project, the Sass files should be compiled into a default.css file that will be used by the Pixate Framework.
We will be building docs for Freestyle once the beta stabilizes. In the meantime, please submit any questions on the Issues page.
The Showcase app is meant to serve as an example application using all of the styles, as well as a reference app for starting a new project or creating themes. We used Storyboards in the app to make it easy to play with, but we had to write a few lines of code to make certain things work.
To enable static scroll views (used for the typography and form pages) that are taller than the device resolution, we added the following viewDidLayoutSubviews method to our view controllers:
- (void)viewDidLayoutSubviews {
[super viewDidLayoutSubviews];
// enable scrolling in the scrollView
[self.scrollView layoutIfNeeded];
self.scrollView.contentSize = self.contentView.bounds.size ;
// place the scrollView in the proper position
CGRect screenBound = [[UIScreen mainScreen] bounds];
CGFloat width = screenBound.size.width;
CGFloat tabBarHeight = [[self.tabBarController tabBar] frame].size.height;
CGFloat navBarHeight = [[self.navigationController navigationBar] frame].size.height;
CGFloat height = screenBound.size.height - tabBarHeight - navBarHeight;
self.scrollView.frame = CGRectMake(0, 0, width, height);
}
Additionally, to set the height of these scroll views, we changed the Size
setting to Freeform
under Simulated Metrics in the Attributes inspector for the view controller.
We also needed code in other places to generate our table view, collection view, and our icons.
We are releasing Freestyle in beta because we really want to hear feedback or feature requests. What would an ideal mobile app toolkit look like for you? Please open a new issue.
Before opening a new issue, please search existing issues.
We currently are not accepting any pull requests, as we want to get Freestyle 1.0 officially out first. In the future we'll welcome contributions with open arms, including new themes and samples from the community.