Skip to content

vance/material-components-ios

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

See MDC site documentation for richer experience.

Material Components is a collection of standalone production-quality components.

Material Components’ visual style is based on the material design specification, developed by a team of iOS engineers and UX designers at Google.

Catalog

Catalog is a demonstration application that showcases the Material Components.

If you haven't checked out the repo yet:

pod try MaterialComponents

If you have checked out the repo:

pod install --project-directory=catalog/ --no-repo-update

Quickstart

1. Install CocoaPods

CocoaPods is the easiest way to get started. If you're new to CocoaPods, check out their getting started documentation.

To install CocoaPods, run the following commands:

sudo gem install cocoapods

2. Create Podfile

Once you've created an iOS application in Xcode you can start using Material Components for iOS.

To initialize CocoaPods in your project, run the following commands:

cd your-project-directory
pod init

3. Edit Podfile

Once you've initialized CocoaPods, add the Material Components for iOS Pod to your target in your Podfile:

target "MyApp" do
  ...
  # Until Material Components for iOS is public:
  pod 'MaterialComponents', :git => 'https://github.com/google/material-components-ios.git'

  # After Material Components for iOS is public:
  # pod 'MaterialComponents'
end

If you are using Swift, don’t forget to uncomment the use_frameworks! line at the top of your Podfile.

Then run the command:

pod install
open your-project.xcworkspace

Now you're ready to get started in Xcode.

4. Usage

Now you’re ready to add a component (e.g. Buttons) to your app! Include the Material Components header for the component you're interested in to your app (detailed below) to get all of the required classes.

Choose from Objective-C or Swift:

Objective-C

#import "MaterialButtons.h"

@implementation ViewController

- (void)viewDidLoad {
  [super viewDidLoad];

  MDCRaisedButton *raisedButton = [MDCRaisedButton new];
  [raisedButton setTitle:@"Raised Button" forState:UIControlStateNormal];
  [raisedButton sizeToFit];
  [raisedButton addTarget:self
                   action:@selector(tapped:)
         forControlEvents:UIControlEventTouchUpInside];

  [self.view addSubview:raisedButton];
}

- (void)tapped:(id)sender {
  NSLog(@"Button was tapped!");
}

@end

Swift

import MaterialComponents

class MDCBuildTestViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        let raiseButton = MDCRaisedButton.init();
        raiseButton.setTitle("Raised Button", forState: .Normal);
        raiseButton.sizeToFit();
        raiseButton.addTarget(self, action: #selector(tapped), forControlEvents: .TouchUpInside);
        self.view.addSubview(raiseButton);
    }

    func tapped(sender: UIButton!){
        NSLog("Button was tapped!");
    }

}

5. What's next?

Attributions

Material Components for iOS uses material design icons, copyright Google Inc. and licensed under CC BY 4.0.

Roboto Font Loader uses the Roboto font, copyright 2011 Google Inc. and licensed under Apache 2.0 without a NOTICE file.

About

Modular and customizable Material Design UI components for iOS

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Objective-C 87.8%
  • Swift 7.8%
  • Shell 2.5%
  • Other 1.9%