zoukankan      html  css  js  c++  java
  • IOS开发UI篇--一个支持图文混排的ActionSheet

    一、简单介绍

    UIActionSheet是IOS提供给我们开发人员的底部弹出菜单控件。一般用于菜单选择、操作确认、删除确认等功能。
    IOS官方提供的下面方式对UIActionView进行实例化:

    - (instancetype)initWithTitle:(NSString *)title delegate:(id<UIActionSheetDelegate>)delegate cancelButtonTitle:(NSString *)cancelButtonTitle destructiveButtonTitle:(NSString *)destructiveButtonTitle otherButtonTitles:(NSString *)otherButtonTitles, ... );

    从这个api我们能够看出,我们仅仅能设置文本标题。包含destructiveButtonTitle、cancelButtonTitle和otherButtonTitles,官方提供的该控件并不支持图文混排。

    但有的时候,交互提给我们的需求又须要我们的ActionSheet具有图文混排的效果。那就须要我们自己仿造系统自带的ActionSheet,完毕该需求。


    项目演演示样例如以下:

    演示图片

    二、使用说明

    第一步、构建数据模型

    @interface Item : NSObject
    @property (nonatomic , strong) NSString *icon;//图片地址
    @property (nonatomic , strong) NSString *title;//标题
    @end

    第二步、依据数据模型构建数据

    Item *item1 = [[Item alloc] init];
    item1.icon = @"journey_phone";
    item1.title = @"15195905888";
    Item *item2 = [[Item alloc] init];
    item2.icon = @"journey_phone";
    item2.title = @"15195905777";
    Item *item3 = [[Item alloc] init];
    item3.icon = @"journey_phone";
    item3.title = @"15195905777";
    NSArray *listData = [NSArray arrayWithObjects:item1,item2,item3, nil];

    第三步、使用以上数据将控件初始化

    PicAndTextActionSheet *sheet = [[PicAndTextActionSheet alloc] initWithList:listData title:@"拨打电话"];
    sheet.delegate = self;//该控件使用的代理模式
    [sheet showInView:self];

    由于该控件使用了代理模式。所以在当前Controller须要实现下面代理方法:

    -(void) didSelectIndex:(NSInteger)index{
    }

    该代理方法,主要是在Controller中能够实如今自己定义ActionSheet中的点击事件。

    三、实现原理

    由于ActionSheet不能支持图片的显示,所以我们就放弃使用扩展UIActionSheet控件的方法。我在本项目中使用的是UITableView+动画。高仿ActionSheet的方法。

    UTableView能够制作列表选项,动画能够实现系统自带ActionSheet的自底向上和渐变效果。

    注意点:

    假设tableview处于uiview上面,uiview整个背景有点击事件。可是我们须要假设我们点击tableview的时候,处理tableview的点击事件,而不是uiview的事件。

    在这里。我们须要推断我们点击事件是否在uiview上还是在uitableview上。

    解决方式例如以下:

    1、实现代理:

    <UIGestureRecognizerDelegate>

    2、让gesture设置为代理

    UITapGestureRecognizer *tapGesture = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tappedCancel)];
    tapGesture.delegate = self;

    3、实现代理方法。推断点击的是否是uiview还是tableview

    -(BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldReceiveTouch:(UITouch *)touch{
        if([touch.view isKindOfClass:[self class]]){
            return YES;
        }
        return NO;
    }

    四、总结

    不论什么一个复杂控件,基本上都是有基础控件组合实现而成。该扩展的ActionSheet也能够用于下面场景:
    场景1



    场景2

    五、下载地址

    github下载地址:https://github.com/yixiangboy/ActionSheetExtension

    假设认为对你还有些用,给一颗star吧。你的支持是我继续的动力。

    blog地址:http://blog.csdn.net/yixiangboy/article/details/46778417

    博主的话

    曾经看过非常多别人的博客,学到不少东西。如今准备自己也開始写写博客,希望能够帮到一些人。


    我的联系方式:
    微博:新浪微博
    博客:http://blog.csdn.net/yixiangboy
    github:https://github.com/yixiangboy

  • 相关阅读:
    C#委托本质探索 四、方法变量内、外混合调用
    calibredrv 对layer做操作
    2021年11月工作笔记
    2022年1月工作资料
    2021年12月工作资料
    MySQL 5.7 MGR原理及部署
    在虚拟机上安装redis集群,redis使用版本为4.0.5,本机通过命令客户端可以连接访问,外部主机一直访问不了
    mongoDB中的的常用语法
    使用Nginx做图片服务器时候,配置之后图片访问一直是 404问题解决
    jquery.cookie() 方法的使用(读取、写入、删除)
  • 原文地址:https://www.cnblogs.com/mfmdaoyou/p/6817528.html
Copyright © 2011-2022 走看看