服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS开发商品页中banner中点击查看图片

iOS开发商品页中banner中点击查看图片

2021-04-20 19:51iOS开发网 IOS

本文文章给大家列出了关于iOS开发商品页中banner中点击查看图片功能源码,有兴趣的朋友参考下吧。

轮翻播放与查看是分开的,轮翻是是用 开源的SDCycleScrollView

这里是给出的是查看的:

?
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
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
//
// FullScreenShowImageView.swift
// joopic
//
// Created by jianxiong li on 16/9/27.
// Copyright © 2016年 joobot. All rights reserved.
//
import Foundation
import UIKit
//图片轮播组件代理协议
protocol FullScreenShowImageViewDelegate{
 //获取数据源
 func galleryDataSource()->[String]
 //获取内部scrollerView的宽高尺寸
 func galleryScrollerViewSize()->CGSize
 
 func hiddenForCliked(index:Int)
}
//图片轮播组件控制器
class FullScreenShowImageView: UIView,UIScrollViewDelegate{
 //代理对象
 var delegate : FullScreenShowImageViewDelegate!
 
 //屏幕宽度
 let kScreenWidth = BWidth
 
 //当前展示的图片索引
 var currentIndex : Int = 0
 
 //数据源
 var dataSource : [String]?
 
 //用于轮播的左中右三个image(不管几张图片都是这三个imageView交替使用)
 var leftImageView , middleImageView , rightImageView : UIImageView?
 
 //放置imageView的滚动视图
 var scrollerView : UIScrollView?
 
 //scrollView的宽和高
 var scrollerViewWidth : CGFloat?
 var scrollerViewHeight : CGFloat?
 
 //页控制器(小圆点)
 var pageControl : UIPageControl?
 
 //加载指示符(用来当iamgeView还没将图片显示出来时,显示的图片)
 var placeholderImage:UIImage!
 
 //自动滚动计时器
 var autoScrollTimer:NSTimer?
 init(frame: CGRect,delegate:FullScreenShowImageViewDelegate) {
  super.init(frame: frame)
  self.delegate = delegate
  praperaUI()
 }
 required init?(coder aDecoder: NSCoder) {
  fatalError("init(coder:) has not been implemented")
 }
 
 func praperaUI() {
  
  //获取并设置scrollerView尺寸
  let size : CGSize = self.delegate.galleryScrollerViewSize()
  self.scrollerViewWidth = size.width
  self.scrollerViewHeight = size.height
  
  //获取数据
  self.dataSource = self.delegate.galleryDataSource()
  //设置scrollerView
  self.configureScrollerView()
  
  //设置加载指示图片
  self.configurePlaceholder()
  
  //设置imageView
  self.configureImageView()
  
  //设置页控制器
  self.configurePageController()
  
  //设置自动滚动计时器
  //self.configureAutoScrollTimer()
  
  self.backgroundColor = UIColor.blackColor()
  
  self.addTapAction()
 }
  
 func addTapAction(){
  //添加组件的点击事件
  let tap = UITapGestureRecognizer(target: self,
           action: #selector(FullScreenShowImageView.handleTapAction(_:)))
  self.addGestureRecognizer(tap)
 }
 
 //点击事件响应
 func handleTapAction(tap:UITapGestureRecognizer)->Void{
  //获取图片索引值
  self.delegate.hiddenForCliked(self.currentIndex)
  self.dismissViewAnimate()
 }
 
 func presentViewAnimate() {
  
  let fr = self.middleImageView?.frame
  self.middleImageView?.frame = CGRect(x: fr!.origin.x, y: 22, width: fr!.width, height: fr!.height)
  UIView.animateWithDuration(10, animations: {
   
   self.middleImageView?.frame = fr!
   
  }) { (_) in
   
  }
  
 }
 
 func dismissViewAnimate() {
  
  let fr = self.middleImageView?.frame
  self.middleImageView?.frame = CGRect(x: fr!.origin.x, y: fr!.origin.y - StatusAndNavHeight, width: fr!.width, height: fr!.height)
  UIView.animateWithDuration(10, animations: {
   
    self.middleImageView?.frame = CGRect(x: fr!.origin.x , y: -42, width: fr!.width, height: fr!.height)
   
  }) { (_) in
   
   self.hidden = true
   self.middleImageView?.frame = fr!
  }
  
 }
 
 //设置scrollerView
 func configureScrollerView(){
  self.scrollerView = UIScrollView(frame: CGRect(x: 0,y: 0,
   width: self.scrollerViewWidth!, height: BHeight))
  
  self.scrollerView?.backgroundColor = UIColor.blackColor()
  self.scrollerView?.delegate = self
  self.scrollerView?.contentSize = CGSize(width: self.scrollerViewWidth! * 3,
            height: BHeight)
  //滚动视图内容区域向左偏移一个view的宽度
  self.scrollerView?.contentOffset = CGPoint(x: self.scrollerViewWidth!, y: 0)
  self.scrollerView?.pagingEnabled = true
  self.scrollerView?.bounces = false
  self.addSubview(self.scrollerView!)
  
 }
 
 //设置加载指示图片
 func configurePlaceholder(){
  //这里我使用ImageHelper将文字转换成图片,作为加载指示符
  let font = UIFont.systemFontOfSize(17)// UIFont.systemFont(ofSize: 17.0, weight: UIFontWeightMedium)
  let size = CGSize(width: self.scrollerViewWidth!, height: self.scrollerViewHeight!)
  placeholderImage = UIImage(named: "图片加载中...")
 }
 
 //设置imageView
 func configureImageView(){
  
  self.leftImageView = UIImageView(frame: CGRect(x: 0, y: (BHeight-scrollerViewHeight!)/2,
   width: self.scrollerViewWidth!, height: self.scrollerViewHeight!))
  
  self.middleImageView = UIImageView(frame: CGRect(x: self.scrollerViewWidth!, y: (BHeight-scrollerViewHeight!)/2,
   width: self.scrollerViewWidth!, height: self.scrollerViewHeight! ));
  
  self.rightImageView = UIImageView(frame: CGRect(x: 2*self.scrollerViewWidth!, y: (BHeight-scrollerViewHeight!)/2,
   width: self.scrollerViewWidth!, height: self.scrollerViewHeight!));
  self.scrollerView?.showsHorizontalScrollIndicator = false
  
  self.leftImageView?.contentMode = UIViewContentMode.ScaleAspectFit
  self.middleImageView?.contentMode = UIViewContentMode.ScaleAspectFit
  self.rightImageView?.contentMode = UIViewContentMode.ScaleAspectFit
  
  //设置初始时左中右三个imageView的图片(分别时数据源中最后一张,第一张,第二张图片)
  if(self.dataSource?.count != 0){
   resetImageViewSource()
  }
  
  self.scrollerView?.addSubview(self.leftImageView!)
  self.scrollerView?.addSubview(self.middleImageView!)
  self.scrollerView?.addSubview(self.rightImageView!)
 }
 
 //设置页控制器
 func configurePageController() {
  self.pageControl = UIPageControl(frame: CGRect(x: kScreenWidth/2-60,
               y: BHeight - 30, width: 120, height: 20))
  self.pageControl?.numberOfPages = (self.dataSource?.count)!
  self.pageControl?.userInteractionEnabled = false
  self.addSubview(self.pageControl!)
 }
 
 //设置自动滚动计时器
 func configureAutoScrollTimer() {
  //设置一个定时器,每三秒钟滚动一次
  autoScrollTimer = NSTimer.scheduledTimerWithTimeInterval(3, target: self, selector: #selector(SliderGalleryController.letItScroll), userInfo: nil, repeats: true)
 }
 
 //计时器时间一到,滚动一张图片
 func letItScroll(){
  let offset = CGPoint(x: 2*scrollerViewWidth!, y: 0)
  self.scrollerView?.setContentOffset(offset, animated: true)
 }
 
 //每当滚动后重新设置各个imageView的图片
 func resetImageViewSource() {
  //当前显示的是第一张图片
  if self.currentIndex == 0 {
   self.leftImageView?.sd_setImageWithURL(NSURL(string: self.dataSource!.last!))
   self.middleImageView?.sd_setImageWithURL(NSURL(string: self.dataSource!.first!))
   let rightImageIndex = (self.dataSource?.count)!>1 ? 1 : 0 //保护
   self.rightImageView?.sd_setImageWithURL(NSURL(string: self.dataSource![rightImageIndex]))
   
   
  }
   //当前显示的是最后一张图片
  else if self.currentIndex == (self.dataSource?.count)! - 1 {
   
   self.leftImageView?.sd_setImageWithURL(NSURL(string:self.dataSource![self.currentIndex-1]))
   self.middleImageView?.sd_setImageWithURL(NSURL(string: self.dataSource!.last!))
   self.rightImageView?.sd_setImageWithURL(NSURL(string: self.dataSource!.first!))
   
  }
   //其他情况
  else{
   
   self.leftImageView?.sd_setImageWithURL(NSURL(string:self.dataSource![self.currentIndex-1]))
   self.middleImageView?.sd_setImageWithURL(NSURL(string: self.dataSource![self.currentIndex]))
   self.rightImageView?.sd_setImageWithURL(NSURL(string: self.dataSource![self.currentIndex+1]))
  }
  
  //设置页控制器当前页码
  self.pageControl?.currentPage = self.currentIndex
 }
 
 
 //scrollView滚动完毕后触发
 func scrollViewDidScroll(scrollView: UIScrollView) {
  //获取当前偏移量
  let offset = scrollView.contentOffset.x
  
  if(self.dataSource?.count != 0){
   
   //如果向左滑动(显示下一张)
   if(offset >= self.scrollerViewWidth!*2){
    //还原偏移量
    scrollView.contentOffset = CGPoint(x: self.scrollerViewWidth!, y: 0)
    //视图索引+1
    self.currentIndex = self.currentIndex + 1
    
    if self.currentIndex == self.dataSource?.count {
     self.currentIndex = 0
    }
   }
   
   //如果向右滑动(显示上一张)
   if(offset <= 0){
    //还原偏移量
    scrollView.contentOffset = CGPoint(x: self.scrollerViewWidth!, y: 0)
    //视图索引-1
    self.currentIndex = self.currentIndex - 1
    
    if self.currentIndex == -1 {
     self.currentIndex = (self.dataSource?.count)! - 1
    }
   }
   
   //重新设置各个imageView的图片
   resetImageViewSource()
   
  }
 }
 
 //手动拖拽滚动开始
 func scrollViewWillBeginDragging(scrollView: UIScrollView) {
  //使自动滚动计时器失效(防止用户手动移动图片的时候这边也在自动滚动)
  //autoScrollTimer?.invalidate()
 }
 
 //手动拖拽滚动结束
 func scrollViewDidEndDragging(scrollView: UIScrollView,
         willDecelerate decelerate: Bool) {
  //重新启动自动滚动计时器
  //configureAutoScrollTimer()
  
 }
}

如何使用:

?
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
var sliderGallery : FullScreenShowImageView!
 var bannerCurrentIndex:Int = 0
 
 //图片轮播组件协议方法:获取内部scrollView尺寸
 func galleryScrollerViewSize() -> CGSize {
  return CGSize(width: BWidth, height: BHeight/2)
 }
 
 //图片轮播组件协议方法:获取数据集合
 func galleryDataSource() -> [String] {
  return self.bannerView.imageURLStringsGroup as! [String]
 }
 
  //点击事件响应
 func hiddenForCliked(index:Int){
  if(bannerCurrentIndex != index){
    self.bannerView.scrollToIndex(Int32(index))
  }
  self.navigationController?.setNavigationBarHidden(false, animated: false)
 }
 
 func showImageGallery(index:Int){
  //初始化图片轮播组件
  if(sliderGallery == nil){
   sliderGallery = FullScreenShowImageView(frame: CGRect(x: 0, y: 0, width: BWidth,
    height: BHeight),delegate:self)
   
   sliderGallery.currentIndex = index
   sliderGallery.resetImageViewSource()
   
   //将图片轮播组件添加到当前视图
   self.view.addSubview(sliderGallery)
   
  }else{
   sliderGallery.currentIndex = index
   sliderGallery.resetImageViewSource()
   sliderGallery.hidden = false
   
  }
  self.sliderGallery.presentViewAnimate()
  self.navigationController?.setNavigationBarHidden(true, animated: false)
 }
 
 //pragma -- SDCycleScrollViewDelegate
 func cycleScrollView(cycleScrollView: SDCycleScrollView!, didSelectItemAtIndex index: Int) {
  print("--------index:\(index)")
  bannerCurrentIndex = index
  self.showImageGallery(index)
  
 }

以上就是本次我们整理的代码全部内容,如果大家学习时候还有任何不明白的地方,可以在下方的留言区讨论,感谢你对服务器之家的支持。

延伸 · 阅读

精彩推荐
  • IOSIOS网络请求之AFNetWorking 3.x 使用详情

    IOS网络请求之AFNetWorking 3.x 使用详情

    本篇文章主要介绍了IOS网络请求之AFNetWorking 3.x 使用详情,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    总李写代码6892021-03-04
  • IOSiOS中时间与时间戳的相互转化实例代码

    iOS中时间与时间戳的相互转化实例代码

    这篇文章主要介绍了iOS中时间与时间戳的相互转化实例代码,非常具有实用价值,需要的朋友可以参考下。...

    张无忌!4812021-03-09
  • IOSiOS逆向教程之logify跟踪方法的调用

    iOS逆向教程之logify跟踪方法的调用

    这篇文章主要给大家介绍了关于iOS逆向教程之logify跟踪方法调用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学...

    Mr.Guo11472021-04-28
  • IOSiOS常见的几个修饰词深入讲解

    iOS常见的几个修饰词深入讲解

    这篇文章主要给大家介绍了关于iOS常见的几个修饰词的相关资料,iOS修饰词包括assign、weak、strong、retain、copy、nonatomic、atomic、readonly、readwrite,文中通过示...

    郡王丶千夜7422021-05-10
  • IOS谈一谈iOS单例模式

    谈一谈iOS单例模式

    这篇文章主要和大家谈一谈iOS中的单例模式,单例模式是一种常用的软件设计模式,想要深入了解iOS单例模式的朋友可以参考一下...

    彭盛凇11872021-01-19
  • IOSiOS APP实现微信H5支付示例总结

    iOS APP实现微信H5支付示例总结

    这篇文章主要介绍了iOS APP实现微信H5支付示例总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    一张小A11332021-06-01
  • IOSiOS10 Xcode8适配7个常见问题汇总

    iOS10 Xcode8适配7个常见问题汇总

    这篇文章主要为大家详细汇总了iOS10 Xcode8适配7个常见问题,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    索马里猫10332021-02-01
  • IOSxcode8提交ipa失败无法构建版本问题的解决方案

    xcode8提交ipa失败无法构建版本问题的解决方案

    xcode升级到xcode8后发现构建不了新的版本。怎么解决呢?下面小编给大家带来了xcode8提交ipa失败无法构建版本问题的解决方案,非常不错,一起看看吧...

    Cinna丶7542021-02-03