Skip to main content

UIButton : How to create a UIButton Programmatically

Sample Code:
// Set a method for this

-(void) addButtonWithFrame :(CGRect ) btnFrame  andName: (NSString *) titleName
{
UIButton *addButton = [UIButton buttonWithType: UIButtonTypeCustom];
// (Value = 0) means NO Button Style.
/* iOS Library provide more Types of UIButton , like
  1. UIButtonTypeRoundedRect (Value = 1), Means a Rounded-Rectangle Style
  2. UIButtonTypeDetailDisclosure (Value = 2), Means a Details Disclosure Button
  3. UIButtonTypeInfoLight (Value = 3), Means an Information button with light background
  4. UIButtonTypeInfoDark (Value = 4), Means an Information Button with dark background
  5. UIButtonTypeContactAdd (Value = 5), Means a contact add button.
You can choose any one of them. */

//Set Button Frame

addButton.frame = btnFrame;

//Set Tag

addButton.tag = cnt; //cnt = 0,1,2…..so on.

// Set Title

[addButton setTitle : titleName forState: UIControlSateNormal];

//If you want to user touch and title highlighted, changes the state like :
// [addButton setTitle : titleName forState: UIControlStateHighlighted];

//Set Title Color

[addButton setTitileColor: [UIColor darkGrayColor] forState: UIControlStateNormal];

//Set Font

addButton.titleLabel.font = [UIFont fontWithName: @ “FontName” size:14 ];
or
addButton.titleLabel.font = [UIFont systemFontOfSize:14];

//Set Image

[addButton setImage:[UIImage imageNamed:@ “ImageName_Normal”] forState: UIControlStateNormal];
[addButton setImage:[UIImage imageNamed:@ “ImageName_Highlighted”] forState: UIControlStateHighlighted];

// Set Background Image

[addButton setBackgroundImage:[UIImage imageNamed:@ “ImageNormal.png”] forState: UIControlStateNormal];// highlighted
[addButton setBackgroundImage:[UIImage imageNamed:@ “ImageHighlighted.png”] forState: UIControlStateHighlighted];

// Set your custom Image, means add a ImageView on Button

UIImageView *myImageView = [[UIImageView alloc] initWithFrame: CGRectMake( 0,0, btnFrame.frame.size.width, btnFrame.frame.size.height)];
myImageView.image = [UIImage imageNamed: @ “Image.png”];
[addButton addSubview: myImageView];
[myImageView release];

// Other way to set Image highlighted and normal with Strechable Image

UIImage *normalImage = [UIImage imageNamed:@ “normalImage.png”];
UIImage *strechableNormalImage = [normalImage stretchableImageWithLeftCapWidth: 14 topCapHeight: 0];
[addButton setBackgroundImage: strechableNormalImage forState: UIControlStateNormal];
UIImage *highlightedImage = [UIImage imageNamed:@ “highlightedImage.png”];
UIImage *strechableHighlightedImage = [highlightedImage  stretchableImageWithLeftCapWidth: 14 topCapHeight: 0];
[addButton setBackgroundImage: strechableHighlightedImage forState: UIControlStateHighlighted];

// Set Border Layer border Width and Color
// First you import and add QuartzCore Framework

addButton.layer.borderWidth = 2.0f;
addButton.layer.borderColor = [UIColor blackColor].cgcolor;

// setRadius Corner

addButton.layer.radiusCorner = 9.0f;

//Set Line Break Mode 

addButton.titleLabel.lineBreakMode = UILineBreakModeTrailTruncation;

// Set Action on Button

[addButton addTarget: self  action:@selector(clickOnButtons:) forControlEvents: UIControlEventTouchUpInside];

// Add to SubView  

[self.view addSubview: addButton];
}

//Calling Method

[self addButtonWithFrame:CGRectMake(20,20,120,30) andName:@ “Close”];

Or

CGRect rect;
rect = CGRectMake (20,20,120,30);
NSString *btnName = @ “Close”;
[self addButtonWithFrame:rect andName:btnName];

Comments

Popular posts from this blog

WPF-MVVM: RelayCommand Implementation

In WPF if we are implementing MVVM pattern then we need to play with Command rather than Events. You can use ICommand interface to create each command class. Implementation of ICommand in a class gives you CanExecute(), Execute() methods which take part in the action performed by Command.   Rather than making Command Class for each Command we can implement a generic Relay Command to get Command. Below is a RelayCommand class that we will implement.   ///   <summary>      ///  To register commands in MMVM pattern      ///   </summary>      class   RelayCommands  :  ICommand     {          readonly   Action < object > _execute;          readonly   Predicate < object > _canExecute;  ...

iOS Dev: Encryption in Objective-C

Hello Friends: In this Article/Post, I introduced the one encryption technique in Objective-C.  Encryption Component Features in all  Symmetric Encryption: AES, Blowfish, Twofish, RC2, ARC4, DES, 3DES, PBES1, PBES2. Hash Algorithms :  SHA-1 , SHA256, SHA384, SHA512, MD2, MD4, MD5, HAVAL. Hash Algorithms: RIPEMD128, RIPEMD160, RIPEMD256, RIPEMD320. Encoding: Base64, hex, quoted-printable,  URL-encoding . HMAC with any supported hash algorithm: HMAC-MD5,  HMAC-SHA1 , etc. Password-based Key Derivation Functions: PBKDF1, PBKDF2 PKCS7 -- P7S and P7M creation, decryption, verification. Public key encryption/decryption with digital certificates. Digital signature creation/verification with digital certificates. Bzip2 in-memory compression. Encrypt / decrypt strings or byte data. Return encrypted data as Base64, quoted-printable, or hex-encoded strings. Hash strings or binary data using SHA1, MD2, MD5, HAVAL, SHA384, or SHA512. Public-key encryp...

iPhonegap: Developing a PhoneGap Application

Tutorial: Developing a PhoneGap Application Reference :  Here In this tutorial, you create a fully functional employee directory application with  PhoneGap . You will learn: How to use different local data storage strategies. How to use several PhoneGap APIs such as Geolocation, Contacts, and Camera. How to handle specific mobile problems such as touch events, scrolling, styling, page transitions, etc. How to build an application using a single page architecture and HTML templates. How to build (compile and package) an application for 6 platforms using  PhoneGap Build . To complete this tutorial, all you need is a code editor, a modern browser, and a connection to the Internet. A working knowledge of HTML and JavaScript is assumed, but you don’t need to be a JavaScript guru. Setting Up Download the assets for the workshop  here . Unzip the file anywhere on your file system. If your code editor allows you to “open a directory”, open the phonegap...