Friday, 24 February 2017

Mix navigation bar with main view

In iOS when it comes to work with navigation controller, we need to handle different aspects of the UINavigation bar which is a property of the UINavigationController. 
In my last app , I need to merge the navigation bar into main view to mimic the user there is no navigation bar but still have bar buttons and title in it.

Here I am showing some small but important work we can do with UINavigation bar, which I come up with :

1) Add animation to title of the navigation bar 

 let lblTitle = UILabel(frame:CGRect(x:0, y:0,width:50, height: 50))  
        lblTitle.text = "Items"
        lblTitle.textColor = UIColor.white
         self.navigationItem.titleView = lblTitle
        
        let animation  = CATransition()
        animation.duration  = 3.0
        animation.type = kCATransitionPush

        lblTitle.layer.add(animation, forKey:"moveText")

2) Mix the navigation bar into main view of the screen


 To merge the navigation bar into our main view, we have to remove the separator line between navigation bar and main view. And then cha

To remove the separator line , set background image and shadow image to a blank UIImage , like this one: 

Now change the background color of the navigator bar with the color of main view
        
self.navigationController?.navigationBar.setBackgroundImage(UIImage(), for: .default)
self.navigationController?.navigationBar.shadowImage = UIImage()

If the default background image is used then default shadowImage also used. So to make it work backgroundImage must be changed with shadowImage.




Thursday, 16 February 2017

Working with NSDate

In iOS development  it's very common to work with NSDate. NSDate object returns the current point of time .
    
 NSDate *currentDate = [NSDate date];
The  above line of code will return the current time with date .

Last week  I was working on an app, the requirement was to calculate the difference between two dates and show the difference in number of days.

For example say you have two dates in string as:

NSString * firstDate = @"2015-10-01 05:46:41 UTC"
NSString *secondDate = @"2015-11-01 05:46:41 UTC"

Now to calculate the difference between  two, first of all we have to convert these two string dates to NSDate object.

To convert the string into NSDate object, create a formatter(NSDateFormatter) with format which matches to your string date as:

 NSDateFormatter *formatter = [[NSDateFormatter alloc]init];
 [formatter setDateFormat:@"yyyy-MM-dd HH:mm:ssZ"];

The first line will initialize the NSDateFormatter and the second line will set the date format, as we have our date in this format in this example .

Now we can get the NSDate for an string date. To get the date from string use formatter object as:

NSDate * startDate =  [formatter dateFromString: firstDate];
NSDate *EndDate = [formatter dateFromString: secondDate];

Now you we have two NSDate object. To get the difference between these two , we should check the which date is later . 

To compare two NSDate object , we use compare method as:

if ([EndDate compare: startDate]== NSOrderedDescending){
    //EndDate is later than startDate date

    NSTimeInterval secondsBetween = [EndDate timeIntervalSinceDate: startDate];
   int numOfdaysLeft = secondsBetween/86400 ;
                   
    } 

Summary
Here we create the NSDate object from string, compare two NSDate object and calculate the time interval between two NSDate object and finally get the number of days from time interval .


                

Sunday, 12 February 2017

Working with Swift

Swift is Apple's new development language. When we switch from Objective C to Swift , we need some tricks so that we can reuse the code and can write less code  for our app .

1) Use Extension: 

Try to code less and reuse it whenever it's possible. Follow write once and use many  approach. For example, in our app there may be a requirement that most of the views should have border and round corner .
For this we can  write those line of code for each view in our view controller . But a better approach is that we can  write an extension to UIView, which will make the input view to have border and round corner.

extension UIView{
    
    func makeCornerRound(cornerRadius:CGFloat){
        self.layer.cornerRadius = cornerRadius
        self.layer.masksToBounds = true
    }
    
    func addBorderWith(color:UIColor, width:CGFloat){
        self.layer.borderWidth = width
        self.layer.borderColor = color.cgColor
        
    }

}

To use these as:
let myView = UIView()
myView.makeCornerRound(cornerRadius:3)
myView.addBorderWith(color:UIColor.gray,width:1.0)

2) Optional Unwrapping:

Guard vs If let

 var email:String?
var password:String?
if let mail_id = email{
  if let pwd = password {
    print("Welcome to my app!")
   }
}

The above code can be written with Guard statement like this:
guard let mail = email, let pwd = password  else{
   print("ohh no! we don't have email and password")
   return
}
print("Welcome to my app!")

You can see the difference here. The scope of unwrapped variable remains to the function in which they are unwrapped with Guard statement. But with if let , the scope is limits to the block in which they are unwrapped.

3) Nil Coalescing : 

What if the value of the optional is missing and you want to  perform some action in case of the absence of the value of an optional . Let's understand  this with an example:

var userName:String?

if let name = userName{
  print("Welcome \(user)")
} else{
  print("Welcome Guest")
}

We can short the above code with nil coalescing operator .

let name =  userName ?? "Guest"
print("Welcome \(name)")

Thursday, 2 February 2017

Working with string and character in Swift

In swift string is value type. In Swift string type is built from Unicode scalar values. A unicode scalar is a unique 21 bit number for a character.

To write an arbitrary scalar value , use \u{n}, where n is a 1-8 digit hexadecimal number with a value equal to a valid Unicode code point.
For example:
let dollar = "\u{24}"
let baby:Character = "\u{1f425}"

Using Extended grapheme cluster we can create a single character by many complex script characters.
An Extended grapheme cluster is a sequence of one or more unicode scalar  that produce a  single human readable character.
let eInCircle:Character = "\u{E9}\u{20DD}"

Will print "é⃝"


String indices: 

In swift different characters require different amount of memory  to store , so in order to determine the position of a character, we must iterate over each unicode scalar from start or end of that string .That's why string in swift can not be indexed by integer values.

A) To get the position of the first character , use the startIndex property of the string:
  var name = "Budha"
   
  To get the first character of the name,
   let firstChar =  name[name.startIndex]

B) The endIndex property  is position after the last character in the string. So to access the last character in the string, use:

let endIndex = name.endIndex
let lastChar = name[name.index(before: endIndex)]

C) To check the equality for string and character, we use ==(equal to ) and != (not equal  to )operator. Two string value will be considered equal if their Extended grapheme clusters are canonically equal. Extended grapheme clusters are canonically equal if they have the same linguistic meaning and appearance, even if they are composed from  different Unicode scalars behind the scenes.