iOS tableview实现顶部拉伸效果

2025-05-29 0 81

本文实例为大家分享了ios tableview头部拉伸效果展示的具体代码,例如探探个人信息界面拉伸效果,下拉头像放大

iOS tableview实现顶部拉伸效果

代码:

?

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

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157
//

// personcontroller.m

// spread

//

// created by qiuxuewei on 16/3/21.

// copyright © 2016年 邱学伟. all rights reserved.

//

#import "personcontroller.h"

@interface personcontroller ()<uitableviewdatasource, uitableviewdelegate, uiscrollviewdelegate>{

}

//属性列表

/** 顶部图片视图 */

@property (nonatomic, strong) uiimageview *headerimageview;

@property (nonatomic, strong) uiview *headerbackview;

/** 个人信息界面 */

@property (nonatomic, strong) uitableview *tableview;

@end

@implementation personcontroller

#pragma mark - 懒加载

-(uiview *)headerbackview{

if (_headerbackview == nil) {

_headerbackview = [[uiview alloc] initwithframe:cgrectmake(0, 0, kscreenwidth, 200)];

[_headerbackview setbackgroundcolor:[uicolor lightgraycolor]];

}

return _headerbackview;

}

-(uiimageview *)headerimageview{

if (_headerimageview == nil) {

_headerimageview = [[uiimageview alloc] init];

[_headerimageview setimage:[uiimage imagenamed:@"邱_生活.jpg"]];

[_headerimageview setbackgroundcolor:[uicolor greencolor]];

[_headerimageview setcontentmode:uiviewcontentmodescaleaspectfill];

[_headerimageview setclipstobounds:yes];

}

return _headerimageview;

}

-(uitableview *)tableview{

if (_tableview == nil) {

_tableview = [[uitableview alloc] initwithframe:cgrectmake(0, 0, kscreenwidth, kscreenheight) style:uitableviewstylegrouped];

[_tableview setdatasource:self];

[_tableview setdelegate:self];

}

return _tableview;

}

- (void)viewdidload {

[super viewdidload];

// do any additional setup after loading the view from its nib.

//添加子视图

[self addchildviews];

}

#pragma mark - 类内方法

//添加子视图

-(void)addchildviews{

//添加表格

[self.view addsubview:self.tableview];

//添加头像图片

[self addheaderimageview];

}

//添加头像

-(void)addheaderimageview{

[self.tableview settableheaderview:self.headerbackview];

[self.headerimageview setframe:self.headerbackview.bounds];

[self.headerbackview addsubview:self.headerimageview];

}

#pragma mark - uitableviewdatasource

- (nsinteger)tableview:(uitableview *)tableview numberofrowsinsection:(nsinteger)section{

return 4;

}

-(nsinteger)numberofsectionsintableview:(uitableview *)tableview{

return 2;

}

-(cgfloat)tableview:(uitableview *)tableview heightforrowatindexpath:(nsindexpath *)indexpath{

return 64;

}

-(void)tableview:(uitableview *)tableview didselectrowatindexpath:(nsindexpath *)indexpath{

// 不加此句时,在二级栏目点击返回时,此行会由选中状态慢慢变成非选中状态。

// 加上此句,返回时直接就是非选中状态。

[tableview deselectrowatindexpath:indexpath animated:yes];

}

//初始化cell

-(uitableviewcell *)tableview:(uitableview *)tableview cellforrowatindexpath:(nsindexpath *)indexpath{

static nsstring *id = @"cell";

uitableviewcell *cell = [tableview dequeuereusablecellwithidentifier:id];

if (!cell) {

cell = [[uitableviewcell alloc] initwithstyle:uitableviewcellstylesubtitle reuseidentifier:id];

}

//初始化cell数据!

[cell.textlabel settext:@"阿伟"];

[cell.detailtextlabel settext:@"2016-03-22"];

return cell;

}

//滚动tableview 完毕之后

-(void)scrollviewdidscroll:(uiscrollview *)scrollview{

//图片高度

cgfloat imageheight = self.headerbackview.frame.size.height;

//图片宽度

cgfloat imagewidth = kscreenwidth;

//图片上下偏移量

cgfloat imageoffsety = scrollview.contentoffset.y;

nslog(@"图片上下偏移量 imageoffsety:%f ->",imageoffsety);

//上移

if (imageoffsety < 0) {

cgfloat totaloffset = imageheight + abs(imageoffsety);

cgfloat f = totaloffset / imageheight;

self.headerimageview.frame = cgrectmake(-(imagewidth * f - imagewidth) * 0.5, imageoffsety, imagewidth * f, totaloffset);

}

// //下移

// if (imageoffsety > 0) {

// cgfloat totaloffset = imageheight - abs(imageoffsety);

// cgfloat f = totaloffset / imageheight;

//

// [self.headerimageview setframe:cgrectmake(-(imagewidth * f - imagewidth) * 0.5, imageoffsety, imagewidth * f, totaloffset)];

// }

}

- (void)didreceivememorywarning {

[super didreceivememorywarning];

// dispose of any resources that can be recreated.

}

/*

#pragma mark - navigation

// in a storyboard-based application, you will often want to do a little preparation before navigation

- (void)prepareforsegue:(uistoryboardsegue *)segue sender:(id)sender {

// get the new view controller using [segue destinationviewcontroller].

// pass the selected object to the new view controller.

}

*/

@end

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 iOS tableview实现顶部拉伸效果 https://www.kuaiidc.com/90267.html

相关文章

发表评论
暂无评论