iOS开发-仿大众点评iPad侧边导航栏

简介:

昨天其实已经写了一篇侧边栏的文章,不过感觉还不是很清晰,这篇文章算是补充吧,iPad上看了大众点评的侧边栏,基本上百分之九十类似,具体效果可参考下图:

 

对比昨天主要做了两个修改,一个是图片和文字的显示位置,另外一个就是关于底部的定位和设置的位置在横竖屏时显示的问题,侧边栏的区域是是自己控制的,需要注意一下横竖屏的时候设置一下autoresizingMask,底部图标定位的时候也是一样设置。

导航栏上每个按钮提取出了一个父类GPDockItem,头文件中的代码:

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
//
//  GPDockItem.h
//  GrouponProject
//博客园FlyElephant:http://www.cnblogs.com/xiaofeixiang
//  Created by keso on 15/3/11.
//  Copyright (c) 2015年 keso. All rights reserved.
//
 
#import <UIKit/UIKit.h>
 
@interface  GPDockItem : UIButton
 
-( void )imageSetting:( NSString  *)backgroundImage selectedImage:( NSString  *)selectedImage;
 
@property  ( nonatomic ,strong)   NSString   *title;
 
//背景图片
@property  ( nonatomic ,strong)   NSString   *backgroundImage;
//选中图片
@property  ( nonatomic ,strong)   NSString   *selectedImage;
 
@end

 

相对于之前的代码,主要是添加了设置背景图片和设置选中图片的混合方法,定义了一个Title属性,之后的可以设置文字和图片的位置,重写两个方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
//设置图片区域
-(CGRect)imageRectForContentRect:(CGRect)contentRect{
     CGFloat  width=contentRect.size.width;
     CGFloat  height= contentRect.size.height * 0.7;
     return  CGRectMake(0, 10, width, height);
}
//设置文字区域
-(CGRect)titleRectForContentRect:(CGRect)contentRect{
     CGFloat  width=contentRect.size.width;
     CGFloat  height= contentRect.size.height * 0.3;
     CGFloat  position=contentRect.size.height*0.7;
     return  CGRectMake(0, position, width, height);
}

 设置背景图片和选中图片:

1
2
3
4
5
-( void )imageSetting:( NSString  *)backgroundImage selectedImage:( NSString  *)selectedImage{
     self .backgroundImage=backgroundImage;
 
     self .selectedImage=selectedImage;
}

 设置显示文字和图片在区域内的位置:

1
2
3
4
5
6
7
8
9
10
11
-( void )setTitle:( NSString  *)title{
     [ self  setTitle:title forState:UIControlStateNormal];
     self .titleLabel.textAlignment= NSTextAlignmentCenter ;
     self .titleLabel.font = [UIFont systemFontOfSize:15];
     //正常状态下是灰色
     [ self  setTitleColor:[UIColor grayColor] forState:UIControlStateNormal];
     //不可点击的时候切换文字颜色
     [ self  setTitleColor:[UIColor orangeColor] forState:UIControlStateDisabled];
     //设置图片属性
     self .imageView.contentMode = UIViewContentModeCenter;
}

 GPDockItem.m中的代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
//
//  GPDockItem.m
//  GrouponProject
//博客园FlyElephant:http://www.cnblogs.com/xiaofeixiang
//  Created by keso on 15/3/11.
//  Copyright (c) 2015年 keso. All rights reserved.
//
 
#import "GPDockItem.h"
 
@implementation  GPDockItem
 
/*
// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
- (void)drawRect:(CGRect)rect {
     // Drawing code
}
*/
 
-(instancetype)initWithFrame:(CGRect)frame{
     self =[ super  initWithFrame:frame];
//    if (self) {
////        UIImageView *splitLine = [[UIImageView  alloc] init];
////        splitLine.frame = CGRectMake(0, 0, GPDockItemWidth, 2);
////        splitLine.image = [UIImage imageNamed:@"separator_tabbar_item.png"];
////        [self addSubview:splitLine];
//
//    }
     return  self ;
 
}
-( void )setTitle:( NSString  *)title{
     [ self  setTitle:title forState:UIControlStateNormal];
     self .titleLabel.textAlignment= NSTextAlignmentCenter ;
     self .titleLabel.font = [UIFont systemFontOfSize:15];
     //正常状态下是灰色
     [ self  setTitleColor:[UIColor grayColor] forState:UIControlStateNormal];
     //不可点击的时候切换文字颜色
     [ self  setTitleColor:[UIColor orangeColor] forState:UIControlStateDisabled];
     //设置图片属性
     self .imageView.contentMode = UIViewContentModeCenter;
}
 
-( void )imageSetting:( NSString  *)backgroundImage selectedImage:( NSString  *)selectedImage{
     self .backgroundImage=backgroundImage;
 
     self .selectedImage=selectedImage;
}
 
//设置背景图片
-( void )setBackgroundImage:( NSString  *)backgroundImage{
     
     _backgroundImage=backgroundImage;
     
     [ self  setImage:[UIImage imageNamed:backgroundImage] forState:UIControlStateNormal];
     
}
//设置选中图片
-( void )setSelectedImage:( NSString  *)selectedImage{
     _selectedImage=selectedImage;
     [ self  setImage:[UIImage imageNamed:selectedImage] forState:UIControlStateDisabled];
     
}
//设置图片区域
-(CGRect)imageRectForContentRect:(CGRect)contentRect{
     CGFloat  width=contentRect.size.width;
     CGFloat  height= contentRect.size.height * 0.7;
     return  CGRectMake(0, 10, width, height);
}
//设置文字区域
-(CGRect)titleRectForContentRect:(CGRect)contentRect{
     CGFloat  width=contentRect.size.width;
     CGFloat  height= contentRect.size.height * 0.3;
     CGFloat  position=contentRect.size.height*0.7;
     return  CGRectMake(0, position, width, height);
}
 
-( void )setFrame:(CGRect)frame{
     //固定Item宽高
     frame.size=CGSizeMake(GPDockItemWidth, GPDockItemHeight);
     [ super  setFrame:frame];
}
 
@end

继承自GPDockItem的GPBottomItem,只需要设置横竖屏自动伸缩属性即可:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
//
//  GPBottomItem.m
//  GrouponProject
// FlyElephant--http://www.cnblogs.com/xiaofeixiang
//  Created by keso on 15/3/13.
//  Copyright (c) 2015年 keso. All rights reserved.
//
 
#import "GPBottomItem.h"
 
@implementation  GPBottomItem
 
/*
// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
- (void)drawRect:(CGRect)rect {
     // Drawing code
}
*/
 
-(instancetype)initWithFrame:(CGRect)frame{
     self =[ super  initWithFrame:frame];
     if  ( self ) {
         // 自动伸缩
         self .autoresizingMask=UIViewAutoresizingFlexibleTopMargin;
     }
     return  self ;
}
 
@end

GPDock.h中的定位:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
-( void )addLocation{
     GPBottomItem *tabItem=[[GPBottomItem alloc]init];
     
     [tabItem imageSetting:@ "Toolbar_switchcity.png"  selectedImage:@ "Toolbar_switchcity_selected.png" ];
     
     CGFloat y =  self .frame.size.height - GPDockItemHeight*2-20;
     //设置位置
     tabItem.frame = CGRectMake(0, y, 0, 0);
     
     [tabItem setTitle:@ "北京" ];
     
     //设置选中触摸选中事件
     [tabItem addTarget: self  action: @selector (tabItemTouchEvent:) forControlEvents:UIControlEventTouchDown];
     tabItem.tag =4;
     [ self  addSubview:tabItem];
}

 GPDock.h中的设置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
-( void )addSetting{
     GPBottomItem *tabItem=[[GPBottomItem alloc]init];
     
     [tabItem imageSetting:@ "Toolbar_setting.png"  selectedImage:@ "Toolbar_setting_selected.png" ];
     
       CGFloat y =  self .frame.size.height - GPDockItemHeight-10;
     //设置位置
     tabItem.frame = CGRectMake(0, y, 0, 0);
     
     [tabItem setTitle:@ "设置" ];
     //设置选中触摸选中事件
     [tabItem addTarget: self  action: @selector (tabItemTouchEvent:) forControlEvents:UIControlEventTouchDown];
     tabItem.tag =5;
     [ self  addSubview:tabItem];
}

  两者有相同之处,分开合并都行,具体看将来要实现的业务逻辑,将其添加到GPDock中:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
-(instancetype)initWithFrame:(CGRect)frame{
     self =[ super  initWithFrame:frame];
     if  ( self ) {
         //自动伸缩高度可伸缩,右边距可以伸缩
         self .autoresizingMask=UIViewAutoresizingFlexibleHeight|UIViewAutoresizingFlexibleRightMargin;
        //设置背景图片
         self .backgroundColor=[UIColor colorWithPatternImage:[UIImage imageNamed:@ "Toolbar_bg_tabbar.png" ]];
         
         //添加选项卡
         [ self  addTabItems];
         
         //添加设置
         [ self  addLocation];
         
         //添加设置
         [ self  addSetting];
     }
     return  self ;
}

 最终实现效果如下:

本文转自Fly_Elephant博客园博客,原文链接:http://www.cnblogs.com/xiaofeixiang/p/4334242.html,如需转载请自行联系原作者

相关文章
|
6天前
|
安全 数据处理 Swift
深入探索iOS开发中的Swift语言特性
本文旨在为开发者提供对Swift语言在iOS平台开发的深度理解,涵盖从基础语法到高级特性的全面分析。通过具体案例和代码示例,揭示Swift如何简化编程过程、提高代码效率,并促进iOS应用的创新。文章不仅适合初学者作为入门指南,也适合有经验的开发者深化对Swift语言的认识。
23 9
|
5天前
|
Android开发 Swift iOS开发
探索安卓与iOS开发的差异和挑战
【10月更文挑战第37天】在移动应用开发的广阔舞台上,安卓和iOS这两大操作系统扮演着主角。它们各自拥有独特的特性、优势以及面临的开发挑战。本文将深入探讨这两个平台在开发过程中的主要差异,从编程语言到用户界面设计,再到市场分布的不同影响,旨在为开发者提供一个全面的视角,帮助他们更好地理解并应对在不同平台上进行应用开发时可能遇到的难题和机遇。
|
3天前
|
iOS开发 开发者
探索iOS开发中的SwiftUI框架
【10月更文挑战第39天】在苹果的生态系统中,SwiftUI框架以其声明式语法和易用性成为开发者的新宠。本文将深入SwiftUI的核心概念,通过实际案例展示如何利用这一框架快速构建用户界面,并探讨其对iOS应用开发流程的影响。
|
6天前
|
JSON 前端开发 API
探索iOS开发之旅:打造你的第一个天气应用
【10月更文挑战第36天】在这篇文章中,我们将踏上一段激动人心的旅程,一起构建属于我们自己的iOS天气应用。通过这个实战项目,你将学习到如何从零开始搭建一个iOS应用,掌握基本的用户界面设计、网络请求处理以及数据解析等核心技能。无论你是编程新手还是希望扩展你的iOS开发技能,这个项目都将为你提供宝贵的实践经验。准备好了吗?让我们开始吧!
|
11天前
|
设计模式 前端开发 Swift
探索iOS开发:从初级到高级的旅程
【10月更文挑战第31天】在这篇文章中,我们将一起踏上iOS开发的旅程。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧。我们将从基础开始,逐步深入到更高级的技术和概念。让我们一起探索iOS开发的世界吧!
|
14天前
|
设计模式 前端开发 Swift
探索iOS开发:从初级到高级的旅程
【10月更文挑战第28天】在这篇技术性文章中,我们将一起踏上一段探索iOS开发的旅程。无论你是刚入门的新手,还是希望提升技能的开发者,这篇文章都将为你提供宝贵的指导和灵感。我们将从基础概念开始,逐步深入到高级主题,如设计模式、性能优化等。通过阅读这篇文章,你将获得一个清晰的学习路径,帮助你在iOS开发领域不断成长。
44 2
|
19天前
|
安全 API Swift
探索iOS开发中的Swift语言之美
【10月更文挑战第23天】在数字时代的浪潮中,iOS开发如同一艘航船,而Swift语言则是推动这艘船前进的风帆。本文将带你领略Swift的独特魅力,从语法到设计哲学,再到实际应用案例,我们将一步步深入这个现代编程语言的世界。你将发现,Swift不仅仅是一种编程语言,它是苹果生态系统中的一个创新工具,它让iOS开发变得更加高效、安全和有趣。让我们一起启航,探索Swift的奥秘,感受编程的乐趣。
|
21天前
|
Swift iOS开发 开发者
探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】在苹果生态系统中,SwiftUI的引入无疑为iOS应用开发带来了革命性的变化。本文将通过深入浅出的方式,带领读者了解SwiftUI的基本概念、核心优势以及如何在实际项目中运用这一框架。我们将从一个简单的例子开始,逐步深入到更复杂的应用场景,让初学者能够快速上手,同时也为有经验的开发者提供一些深度使用的技巧和策略。
44 1
|
9天前
|
存储 数据可视化 Swift
探索iOS开发之旅:从新手到专家
【10月更文挑战第33天】在这篇文章中,我们将一起踏上一场激动人心的iOS开发之旅。无论你是刚刚入门的新手,还是已经有一定经验的开发者,这篇文章都将为你提供宝贵的知识和技能。我们将从基础的iOS开发概念开始,逐步深入到更复杂的主题,如用户界面设计、数据存储和网络编程等。通过阅读这篇文章,你将获得成为一名优秀iOS开发者所需的全面技能和知识。让我们一起开始吧!
|
10天前
|
移动开发 Java Android开发
探索Android与iOS开发的差异性与互联性
【10月更文挑战第32天】在移动开发的大潮中,Android和iOS两大平台各领风骚。本文将深入浅出地探讨这两个平台的开发差异,并通过实际代码示例,展示如何在各自平台上实现相似的功能。我们将从开发环境、编程语言、用户界面设计、性能优化等多个角度进行对比分析,旨在为开发者提供跨平台开发的实用指南。
32 0