(iOS)可以显示图片的类似网易新闻的头部滚动条

前言, 最近发现一类效果类似网易新闻头部滚动条的效果,不过是可以显示图片(上, 中, 左, 右)和文字, 最近在比较闲的时候顺带把这些效果也一并实现了, 那么这一类的各种效果大致上就实现了Demo地址,供有需要的朋友可以参考

增加效果

图片在左边

图片在右边.gif

图片在上面.gif

只显示图片.gif
只显示图片.gif

原来的效果 --- 只显示文字


oc版滚动示例.gif
关于实现部分, 新增显示的图片的效果, 其实对原来的影响并不大
  • 只是更换了一下ZJSegmentView里面显示文字的控件, 之前是使用label,那么就只是考虑到显示文字, 所以要实现显示图片, 只需要替换这个label为其他的控件就好了.
  • 所以, 如果你需要参考ZJScrollPageView是怎么实现的, 你可以先看看这篇介绍
  • 所以这里, 就新增了一个ZJTitleView用于显示标题和图片, 这个里面的处理也并不复杂, 一个imageView用来显示图片, 一个label用来显示文字, 根据不同的设置必要的添加这两个控件上去

@property (strong, nonatomic) UIImageView *imageView;
@property (strong, nonatomic) UILabel *label;

  • ZjTitleView里面同时增加了几个public的属性, 用于外部调用

@interface ZJTitleView : UIView
/// 这个属性用于设置放大和缩小倍数
@property (assign, nonatomic) CGFloat currentTransformSx;
/// 这个用来设置图片显示的位置
@property (assign, nonatomic) TitleImagePosition imagePosition;
/// 这个用于设置标题
@property (strong, nonatomic) NSString *text;
/// 这个用于设置标题的颜色
@property (strong, nonatomic) UIColor textColor;
/// 这个用于设置标题文字的字体
@property (strong, nonatomic) UIFont font;
/// 这个用于标示是否被选中
@property (assign, nonatomic, getter=isSelected) BOOL selected;
/
代理方法中推荐只设置下面的属性, 当然上面的属性设置也会有效, 不过建议上面的设置在style里面设置 */
@property (strong, nonatomic) UIImage *normalImage;
@property (strong, nonatomic) UIImage *selectedImage;

* ZJTitleView提供两个方法给ZJSegmentView使用,不是提供给外部使用的 `- (CGFloat)titleViewWidth;`,`- (void)adjustSubviewFrame;`

/// 这个方法返回当前的imageView和label的总共的宽度, 用于ZJSegmentView来设置titleView的宽度

  • (CGFloat)titleViewWidth {
    CGFloat width = 0.0f;
    switch (self.imagePosition) {
    case TitleImagePositionLeft:
    width = _imageWidth + _titleSize.width;
    break;
    case TitleImagePositionRight:
    width = _imageWidth + _titleSize.width;
    break;
    case TitleImagePositionCenter:
    width = _imageWidth;
    break;
    default:
    width = _titleSize.width;
    break;
    }
    return width;
    }

/// 这个方法是给ZJSegmentView使用
/// 当设置了需要显示图片的时候
/// 这个方法里面会根据不同的图片位置, 来设置imageView和label的frame

  • (void)adjustSubviewFrame {
    _isShowImage = YES;

    CGRect contentViewFrame = self.bounds;
    contentViewFrame.size.width = [self titleViewWidth];
    contentViewFrame.origin.x = (self.frame.size.width - contentViewFrame.size.width)/2;
    self.contentView.frame = contentViewFrame;
    self.label.frame = self.contentView.bounds;

    [self addSubview:self.contentView];
    [self.label removeFromSuperview];
    [self.contentView addSubview:self.label];
    [self.contentView addSubview:self.imageView];

    switch (self.imagePosition) {
    case TitleImagePositionTop: {
    self.imageView.frame = CGRectMake(0, 0, _imageWidth, _imageHeight);
    CGPoint center = self.imageView.center;
    center.x = self.label.center.x;
    self.imageView.center = center;

          CGFloat labelHeight = self.contentView.frame.size.height - _imageHeight;
          CGRect labelFrame = self.label.frame;
          labelFrame.origin.y = _imageHeight;
          labelFrame.size.height = labelHeight;
          self.label.frame = labelFrame;
          break;
      }
      case TitleImagePositionLeft: {
          
          CGRect labelFrame = self.label.frame;
          labelFrame.origin.x = _imageWidth;
          labelFrame.size.width = self.contentView.frame.size.width - _imageWidth;
          self.label.frame = labelFrame;
          
          CGRect imageFrame = CGRectZero;
          imageFrame.size.height = _imageHeight;
          imageFrame.size.width = _imageWidth;
          imageFrame.origin.y = (self.contentView.frame.size.height - imageFrame.size.height)/2;
          self.imageView.frame = imageFrame;
          
          break;
      }
      case TitleImagePositionRight: {
          CGRect labelFrame = self.label.frame;
          labelFrame.size.width = self.contentView.frame.size.width - _imageWidth;
          self.label.frame = labelFrame;
          
          CGRect imageFrame = CGRectZero;
          imageFrame.origin.x = CGRectGetMaxX(self.label.frame);
          imageFrame.size.height = _imageHeight;
          imageFrame.size.width = _imageWidth;
          imageFrame.origin.y = (self.contentView.frame.size.height - imageFrame.size.height)/2;
          self.imageView.frame = imageFrame;
          break;
      }
      case TitleImagePositionCenter:
          
          self.imageView.frame = self.contentView.bounds;
          [self.label removeFromSuperview];
          break;
      default:
          break;
    

    }

}


* 以上的属性的set方法均被重写了, 用于设置ZJTitleView的对应控件的属性, 例如如下的一些setter

> 
/// 设置普通状态的图片, 同时记录下图片的尺寸用于设置imageView的尺寸
- (void)setNormalImage:(UIImage *)normalImage {
    _normalImage = normalImage;
    _imageWidth = normalImage.size.width;
    _imageHeight = normalImage.size.height;
    self.imageView.image = normalImage;
}

/// 设置选中状态的图片
> 
- (void)setSelectedImage:(UIImage *)selectedImage {
    _selectedImage = selectedImage;
    self.imageView.highlightedImage = selectedImage;
}
- (void)setFont:(UIFont *)font {
    _font = font;
    self.label.font = font;
}

/// 设置文字, 同时计算出文字的尺寸
> 
- (void)setText:(NSString *)text {
    _text = text;
    self.label.text = text;
    CGRect bounds = [text boundingRectWithSize:CGSizeMake(MAXFLOAT, 0.0) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName: self.label.font} context:nil];
    _titleSize = bounds.size;
}

/// 设置文字颜色
> 
- (void)setTextColor:(UIColor *)textColor {
    _textColor = textColor;
    self.label.textColor = textColor;
}

/// 设置是否选中
> 
- (void)setSelected:(BOOL)selected {
    _selected = selected;
    self.imageView.highlighted = selected;
}


* 使用上只需要设置style里面的属性`showImage`和`imagePosition`再增加一个代理方法

> 
 ZJSegmentStyle *style = [[ZJSegmentStyle alloc] init];
    /// 显示遮盖
    style.showLine = YES;
    /// 设置滚动条高度
    style.segmentHeight = 60;
    /// 显示图片 (在显示图片的时候只有下划线的效果可以开启, 其他的'遮盖','渐变',效果会被内部关闭)
    style.showImage = YES;
    /// 平分宽度
//    style.scrollTitle = NO;
    /// 图片位置
    style.imagePosition = TitleImagePositionTop;
    // 当标题(和图片)宽度总和小于ZJScrollPageView的宽度的时候, 标题会自适应宽度
    

  • (void)setUpTitleView:(ZJTitleView *)titleView forIndex:(NSInteger)index {
    /// 设置普通状态图片
    titleView.normalImage = [UIImage imageNamed:[NSString stringWithFormat:@"normal_%ld", index+1]];
    /// 设置选中状态图片
    titleView.selectedImage = [UIImage imageNamed:@"selected"];
    }

> 到目前为止,这个小框架的功能算是比较丰富的了, 如果你正好需要, 可以用用试试, 如果你有使用问题可以联系我[Demo地址](https://github.com/jasnig/ZJScrollPageView)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,013评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,205评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,370评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,168评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,153评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,954评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,271评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,916评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,382评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,877评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,989评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,624评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,209评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,199评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,418评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,401评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,700评论 2 345

推荐阅读更多精彩内容