iOS_20_微博『更多』页面

最终效果图:

MoreViewController.m

//
//  MoreViewController.m
//  20_帅哥no微博
//
//  Created by beyond on 14-8-4.
//  Copyright (c) 2014年 com.beyond. All rights reserved.
//

#import "MoreViewController.h"

@interface MoreViewController ()
{
    // more.plist根是字典,有两对Key Value,其中有一对是zh_CN,对应的值是数组,数组的长度就是有多少个分组,数组的每一个元素也是一个数组,

    // 由不同的分组,组成的数组
    NSArray *_groups;
}

@end

@implementation MoreViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
    log(@"view  %@",NSStringFromCGRect(self.view.frame))  ;

    // 1.设置导航条上面 右边的设置按钮
    [self setRightBarButtonItem];

    // 2.加载more.plist
    [self loadPlistOfMore];

    // 3.设置tableView的全局背景
    [self setTableViewGlobalBg];

    // 4.添加 退出按钮 到tableView的最底部的TableFooterView
    [self addEixtBtnAtBottom];
}

// 1,设置导航条上面 右边的按钮
- (void)setRightBarButtonItem
{
    self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc] initWithTitle:@"设置" style:UIBarButtonItemStylePlain target:self action:@selector(settings)];
}
// 2,加载more.plist文件
- (void)loadPlistOfMore
{
    NSURL *url = [[NSBundle mainBundle] URLForResource:@"more" withExtension:@"plist"];
    // 由一个个分组 组成的数组,分组的成员也就是数组,则一行行组成的数组
    _groups = [NSDictionary dictionaryWithContentsOfURL:url][@"zh_CN"];
}

// 3,设置tableView的全局背景
- (void)setTableViewGlobalBg
{
    // 清除ios 7 中tableView顶部的多出的空白区域
    self.automaticallyAdjustsScrollViewInsets = NO;
    // 设置scrollView额外的滚动区域
//    self.tableView.contentInset = UIEdgeInsetsMake(<#CGFloat top#>, <#CGFloat left#>, <#CGFloat bottom#>, <#CGFloat right#>)
    // 重要~ ~当tableview的样式为group时,如果想更换背景,必须先清除条纹状的自带的backgroundView,然后才可以设置tableView的背景颜色
    self.tableView.backgroundView = nil;
    self.tableView.backgroundColor = kGlobalBg;

    // 缩小每一分组之间的间距
    self.tableView.sectionHeaderHeight = 0;
    self.tableView.sectionFooterHeight = 5;
}

// 4,创建退出按钮 并添加到tableView的最底部的TableFooterView
- (void)addEixtBtnAtBottom
{
    // 1,创建一个footerView,将它作为tableView的TableFooterView
    UIView *footerView = [[UIView alloc] init];
    // tableView的TableFooterView的宽度固定是320,只有高度可调节
    footerView.frame = CGRectMake(0, 0, 320, 60);
    // 将刚才创建的footerView作为tableView的TableFooterView,目的是防止用户点击底部dockItem时不小心点到了退出按钮,因此要设置一个额外的空间,补充一下TableFooterView的宽度固定是320
    self.tableView.tableFooterView = footerView;

    // 2,创建退出按钮 并添加到tableView的最底部的TableFooterView
    UIButton *btnExit = [UIButton buttonWithType:UIButtonTypeCustom];
    // footerView是作为tableView的TableFooterView存在,按钮是加到了footerView里面,这儿按钮的frame  x 10 y 5是相对于footerView的
    btnExit.frame = CGRectMake(10, 5, 300, 40);
    // 按钮上字体大小
    btnExit.titleLabel.font = [UIFont systemFontOfSize:17];
    // 按钮的监听点击事件
    [btnExit addTarget:self action:@selector(exitBtnClick) forControlEvents:UIControlEventTouchUpInside];

    // 分类方法,设置按钮正常和高亮时背景图片(可拉伸)
    [btnExit setBtnBgImgForNormalAndHighightedWithName:@"common_button_red.png"];
    // 设置按钮上的文字,最后一组,数组只有一行,每一行就是一个字典
    NSString *btnTitle = [_groups lastObject][0][@"name"];
    [btnExit setTitle:btnTitle forState:UIControlStateNormal];

    // 3,最重要的一步,将刚才创建的 退出按钮 添加到tableView的TableFooterView
    //[footerView addSubview:btnExit];
    [self.tableView.tableFooterView addSubview:btnExit];

}
// 响应点击设置点击事件
- (void)settings
{
    log(@"点击了设置按钮");
}
// 点击 退出按钮
- (void)exitBtnClick
{
    // cancelButtonTitle 黑色
    // destructiveButtonTitle 红色
    // otherButtonTitles 灰白色
    UIActionSheet *actionSheet = [[UIActionSheet alloc] initWithTitle:@"确定退出此账号?" delegate:nil cancelButtonTitle:@"取消" destructiveButtonTitle:@"红色" otherButtonTitles:@"其他", nil];

    // UIActionSheet最好是显示到Window上面,这样就不怕点不中了,因为有时候控制器的view不一定占整个窗口大小
    [actionSheet showInView:self.view.window];
}

// 点击 设置按钮
- (void)setting
{
    log(@"设置");
}
// 代理方法,点击了某行时调用
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    [tableView deselectRowAtIndexPath:indexPath animated:YES];
}

#pragma mark - 数据源方法
// 共有多少组  最后一个组是特别的退出按钮,故不进入循环使用
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    return _groups.count - 1;
}

// 每一组的行数
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    // 取得由每一行组成的数组
    NSArray *rows = _groups[section];
    // 返回该组的行数
    return rows.count;
}

// 每一组的每一行显示特有的内容
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{

    static NSString *cellID = @"beyond";
    // 1.先获得池中的cell
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:cellID];
    // 如果为空,才创建新的
    if (cell == nil) {
        // 创建新的cell
        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellID];
        // 1.1.清除文本标签的背景
        cell.textLabel.backgroundColor = [UIColor clearColor];
        // 1.2.设置文本标签高亮时的文字颜色同样为默认的文字颜色 (不让它变色)
        cell.textLabel.highlightedTextColor = cell.textLabel.textColor;

        // 1.3.重点,创建时就,初始化cell的背景view和选中时的背景view
        UIImageView *bgImgView = [[UIImageView alloc] init];
        cell.backgroundView = bgImgView;

        UIImageView *selectedBgImgView = [[UIImageView alloc] init];
        cell.selectedBackgroundView = selectedBgImgView;
    }
    // 2.设置cell独一无二的内容
    // 设置显示的标题文字  第几组-->第几行--->字典
    cell.textLabel.text =  _groups[indexPath.section][indexPath.row][@"name"];

    // 3.设置cell的背景图片
    // 先取出cell背景view
    UIImageView *bgImgView = (UIImageView *)cell.backgroundView;
    UIImageView *selectedBgImgView = (UIImageView *)cell.selectedBackgroundView;

    // 分情况得出cell的背景图片文件名
    // 该组中,由每一行组成的数组
    NSArray *rows = _groups[indexPath.section];
    // 得到该组的,总行数
    int rowNum = rows.count;
    NSString *name = nil;

    if (rowNum == 1) {
        // 如果所在组只有一行,使用四角全是半角的图片
        name = @"common_card_background.png";
    } else if (indexPath.row == 0) {
        // 如果所在组不只一行,且当前行是所在组的第一行,使用上半为圆角的图片
        name = @"common_card_top_background.png";
    } else if (indexPath.row == rowNum - 1) {
        // 如果所在组不只一行,且当前行是所在组的最后一行,使用下半为圆角的图片
        name = @"common_card_bottom_background.png";
    } else { // 中间
        // 如果所在组不只一行,且当前行不在组的第一行也不在组的最后一行,使用四周无圆角的图片
        name = @"common_card_middle_background.png";
    }

    // 设置cell的正常和选中时的背景图片
    bgImgView.image = [UIImage imageStretchedWithName:name];
    selectedBgImgView.image = [UIImage imageStretchedWithName:[name fileNameInsertSuffixBeforeExtension:@"_highlighted"]];

    // 4.设置最右边的箭头指示器,分文字和图片两种情况讨论
    if (indexPath.section == 2) {
        // 如果是第2组 ,则显示文字,"阅读模式 - 主题"
        UILabel *label = [[UILabel alloc] init];
        // 清除标签背景色
        label.backgroundColor = [UIColor clearColor];
        // 标签文字大小
        label.font = [UIFont systemFontOfSize:13];
        // 标签文字颜色
        label.textColor = [UIColor grayColor];
        // 标签文字靠右
        label.textAlignment = NSTextAlignmentRight;
        // 标签frame的宽高
        label.bounds = CGRectMake(0, 0, 100, 30);
        // 该组的第1行显示 "有图模式" ,第2行显示 "经典主题"
        label.text = (indexPath.row == 0) ? @"有图模式" : @"经典主题";
        // 最后将自定义最右边的view设置为cell的附属view
        cell.accessoryView = label;
    } else {
        // 如果是其他的组,显示向右的图片箭头
        cell.accessoryView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"common_icon_arrow.png"]];
    }
    // 5.返回cell
    return cell;
}

@end

『更多』页面的数据来源more.plist

iOS_20_微博『更多』页面

时间: 2024-12-20 15:50:03

iOS_20_微博『更多』页面的相关文章

iOS_20_微博新特性页面

最终效果图: BeyondAppDelegate.m // // BeyondAppDelegate.m // 20_帅哥no微博 // // Created by beyond on 14-8-3. // Copyright (c) 2014年 com.beyond. All rights reserved. // #import "BeyondAppDelegate.h" #import "BeyondViewController.h" #import &quo

『AngularJS』$location 服务

参考: ng.$location Developer Guide: Angular Services: Using $location 简介 $location服务解析在浏览器地址栏中的URL(基于window.location)并且让URL在你的应用中可用.改变在地址栏中的URL会作用到$location服务,同样的,改变$location服务也会改变浏览器的地址栏.(可以使用$location进行重定向等操作) $location服务: 暴露浏览器地址栏中的URL,让你可以: 监察URL.

『ENGLISH』

以A字母开头的词汇 英文 中文 abstract module 抽象模组 access 访问.存取 access control 存取控制 access control information 存取控制资讯 access mechanism 存取机制 access rights 存取权限 accessibility 无障碍性 accessibility information 无障碍网页资讯 accessibility problem 无障碍网页问题 accessible 无障碍的 access

谈谈前端『新』技术

技术这个行当,永远会有新东西出来,不进则退.更关键的是,前端比起整个软件工程乃至计算机科学体系来说,是个相对新生草莽的领域,近年来前端生态的发展其实都是在向其他领域吸收和学习,不论是开发理念.工程实践还是平台本身(规范.浏览器).所谓的『根正苗红』的前端,不过是整个发展进程中探索的一个阶段而已,那个时代的最佳实践,很多到今天都已经不再适用.过往的经验固然有价值,但这些经验如果不结合对新事物本身的了解,就很难产生正确的判断.这里需要强调的是,学习新事物并不是为了不考虑实际需求的滥用,而是为了获取足

『转』★嗨聊

前端一直是一块充满惊喜的土地,不仅是那些富有创造性的页面,还有那些惊赞的效果及不断推出的新技术.像node.js这样的后端开拓者直接将前端人员的能力扩大到了后端.瞬间就有了一统天下的感觉,来往穿梭于前后端之间代码敲得飞起,从此由前端晋升为'前后端'. 图片来自G+ 本文将使用Node.js加web socket协议打造一个网页即时聊天程序,取名为HiChat,中文翻过来就是'嗨聊',听中文名有点像是专为寂寞单身男女打造的~ 其中将会使用到express和socket.io两个包模块,下面会有介绍

『细节』是什么

图片来自网络,作者不详 只要是职场人士,谈及『细节』二字估计很容易让人联想到『细节决定成败』这句话.由于这句话无人不知.无人不晓,以至于容易将『细节』误以为是口号.就我在工作中的感受,发现确实大多数人是将『关注细节』当作是口号.正因如此,我想借这篇文章与大家探讨一下我所理解的『细节』究竟是什么. 首先,『细节』代表态度--将工作做到位.『做到位』与『做完』是全然不同的工作水准,前者包含后者但比后者有更深的内涵.其一,将工作努力做到不会出错,并在出错时从根源上加以解决和预防.对于软件工程师来说,我

iOS_20_微博骨架搭建

最终效果图: BeyondViewController.m // // BeyondViewController.m // 20_帅哥no微博 // // Created by beyond on 14-8-3. // Copyright (c) 2014年 com.beyond. All rights reserved. // 这个就是主控制器,分为两块,下面是Dock栏,上面是显示不同的子控制器的view,子控制器最好用导航控制器包装一下,这样子控制器就自带了导航条,左按钮,标题,右按钮 /

『方案』《女友十年精华》 ORC 图片 文字识别 详解

目的需求: 2008年,遇到一本电子书 <女友十年精华> 觉得很美,想 私藏 这些文章: >网络搜索文章 —— 没有找到: >反编译程序 —— 所有文字 都是图片格式(部分文章的 非规律乱码 即为证明,且试用  Adobe Director 反编译 确是图片无疑) >总计 310篇文章 —— 如何降低 工作复杂度 得到 文本格式的文章? 最后方案: >写区域截屏软件,将一篇文章 截成多图 (图片文字行 有重复): >过滤 文章多图 的背景图片(背景图片 会干扰 O

『教程』L0、L1与L2范数_简化理解

『教程』L0.L1与L2范数 一.L0范数.L1范数.参数稀疏 L0范数是指向量中非0的元素的个数.如果我们用L0范数来规则化一个参数矩阵W的话,就是希望W的大部分元素都是0,换句话说,让参数W是稀疏的. 既然L0可以实现稀疏,为什么不用L0,而要用L1呢?一是因为L0范数很难优化求解(NP难问题),二是L1范数是L0范数的最优凸近似,而且它比L0范数要容易优化求解.所以大家才把目光和万千宠爱转于L1范数. 总结:L1范数和L0范数可以实现稀疏,L1因具有比L0更好的优化求解特性而被广泛应用.