无法使用 Parse 在滚动视图中缩放 UIImage
Can't zoom UIImage in a Scroll View with Parse
谁可以帮助缩放滚动视图。使用 Parse 获取图片,但无法缩放。
通过所有可能的功能都不起作用 - aImg 这是(UIImage)到 setupPhotosInScrollView 功能,任何人都可以帮忙吗?尝试过框架但没有任何帮助
代码
class AdPhotos: UIViewController, UIScrollViewDelegate {
/*--- VIEWS ---*/
@IBOutlet weak var containerScrollView: UIScrollView!
/*--- VARIABLES ---*/
var adObj = PFObject(className: ADS_CLASS_NAME)
var photosArray = [UIImage]()
// ------------------------------------------------
// MARK: - VIEW DID LOAD
// ------------------------------------------------
override func viewDidLoad() {
super.viewDidLoad()
// Ad Title
adTitleLabel.text = "\(adObj[ADS_TITLE]!)"
// Get photos
let imageFile = adObj[ADS_IMAGE1] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 1")
}}})
DispatchQueue.main.async {
if self.adObj[ADS_IMAGE2] != nil {
self.pageControl.numberOfPages = 2
let imageFile = self.adObj[ADS_IMAGE2] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 2")
}}})
}
if self.adObj[ADS_IMAGE3] != nil {
self.pageControl.numberOfPages = 3
let imageFile = self.adObj[ADS_IMAGE3] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 3")
}}})
}
if self.adObj[ADS_IMAGE4] != nil {
self.pageControl.numberOfPages = 4
let imageFile = self.adObj[ADS_IMAGE4] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 4")
}}})
}
if self.adObj[ADS_IMAGE5] != nil {
self.pageControl.numberOfPages = 5
let imageFile = self.adObj[ADS_IMAGE5] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 5")
}}})
}
}
}
// ------------------------------------------------
// MARK: - SETUP PHOTOS IN SCROLLVIEW
// ------------------------------------------------
@objc func setupPhotosInScrollView() {
var X:CGFloat = 0
let Y:CGFloat = 0
let W:CGFloat = view.frame.size.width
let H:CGFloat = view.frame.size.height
let G:CGFloat = 0
var counter = 0
// Loop to create ImageViews
for i in 0..<photosArray.count {
counter = i
// Create a ImageView
let aImg = UIImageView(frame: CGRect(x: X, y: Y, width: W, height: H))
aImg.tag = i
aImg.contentMode = .scaleAspectFit
aImg.image = photosArray[i]
// Add ImageViews based on X
X += W + G
containerScrollView.addSubview(aImg)
} // ./ FOR loop
// Place Buttons into a ScrollView
containerScrollView.contentSize = CGSize(width: W * CGFloat(counter+2), height: H)
}
// ------------------------------------------------
// MARK: - CHANGE PAGE CONTROL PAGES ON SCROLL
// ------------------------------------------------
func scrollViewDidScroll(_ scrollView: UIScrollView) {
let pageWidth = containerScrollView.frame.size.width
let page = Int(floor((containerScrollView.contentOffset.x * 2 + pageWidth) / (pageWidth * 2)))
pageControl.currentPage = page
}
}
我认为您不需要 ScrollView 和管理 Pagingnation。您需要 CollectionView 并启用分页选项 From story-bored.
拖动 Collection 在您的 ViewController 中查看。启用分页选项
来自 属性 选择器。
将 CollectionView(leading
, trailing
, top
, bottom
) 分配给 View(leading
, trailing
, top
, bottom
)
将 CollectionView 单元格拖到 CollectionView 中。调整单元格大小以填充
整个Collection视图
将 Scrollview 添加到 CollectionView 单元格中并添加 ScrollView(leading
,
trailing
, top
, bottom
) == Collection查看单元格(leading
,
trailing
, top
, bottom
)
在Scrollview中添加imageView并添加imageView(leading
,
trailing
, top
, bottom
) == 滚动视图 (leading
,
trailing
、top
、bottom
)
并且 CollectionView cell 的宽度和高度相等。
- 实现
DataSource
和 Delegate
方法 For CollectionView.
为了缩放,请将以下代码添加到您的 CollectionView Cell
import UIKit
class CustomeCellCollectionViewCell: UICollectionViewCell , UIScrollViewDelegate {
@IBOutlet var imageView : UIImageView!
@IBOutlet var scrollView : UIScrollView!
override func awakeFromNib() {
super.awakeFromNib()
scrollView.delegate = self
scrollView.minimumZoomScale = 1.0
scrollView.maximumZoomScale = 6.0
}
func viewForZooming(in scrollView: UIScrollView) -> UIView? {
return feedsImageView
}
}
谁可以帮助缩放滚动视图。使用 Parse 获取图片,但无法缩放。 通过所有可能的功能都不起作用 - aImg 这是(UIImage)到 setupPhotosInScrollView 功能,任何人都可以帮忙吗?尝试过框架但没有任何帮助
代码
class AdPhotos: UIViewController, UIScrollViewDelegate {
/*--- VIEWS ---*/
@IBOutlet weak var containerScrollView: UIScrollView!
/*--- VARIABLES ---*/
var adObj = PFObject(className: ADS_CLASS_NAME)
var photosArray = [UIImage]()
// ------------------------------------------------
// MARK: - VIEW DID LOAD
// ------------------------------------------------
override func viewDidLoad() {
super.viewDidLoad()
// Ad Title
adTitleLabel.text = "\(adObj[ADS_TITLE]!)"
// Get photos
let imageFile = adObj[ADS_IMAGE1] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 1")
}}})
DispatchQueue.main.async {
if self.adObj[ADS_IMAGE2] != nil {
self.pageControl.numberOfPages = 2
let imageFile = self.adObj[ADS_IMAGE2] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 2")
}}})
}
if self.adObj[ADS_IMAGE3] != nil {
self.pageControl.numberOfPages = 3
let imageFile = self.adObj[ADS_IMAGE3] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 3")
}}})
}
if self.adObj[ADS_IMAGE4] != nil {
self.pageControl.numberOfPages = 4
let imageFile = self.adObj[ADS_IMAGE4] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 4")
}}})
}
if self.adObj[ADS_IMAGE5] != nil {
self.pageControl.numberOfPages = 5
let imageFile = self.adObj[ADS_IMAGE5] as? PFFile
imageFile?.getDataInBackground(block: { (data, error) in
if error == nil { if let imageData = data {
self.photosArray.append(UIImage(data: imageData)!)
self.setupPhotosInScrollView()
print("PHOTO 5")
}}})
}
}
}
// ------------------------------------------------
// MARK: - SETUP PHOTOS IN SCROLLVIEW
// ------------------------------------------------
@objc func setupPhotosInScrollView() {
var X:CGFloat = 0
let Y:CGFloat = 0
let W:CGFloat = view.frame.size.width
let H:CGFloat = view.frame.size.height
let G:CGFloat = 0
var counter = 0
// Loop to create ImageViews
for i in 0..<photosArray.count {
counter = i
// Create a ImageView
let aImg = UIImageView(frame: CGRect(x: X, y: Y, width: W, height: H))
aImg.tag = i
aImg.contentMode = .scaleAspectFit
aImg.image = photosArray[i]
// Add ImageViews based on X
X += W + G
containerScrollView.addSubview(aImg)
} // ./ FOR loop
// Place Buttons into a ScrollView
containerScrollView.contentSize = CGSize(width: W * CGFloat(counter+2), height: H)
}
// ------------------------------------------------
// MARK: - CHANGE PAGE CONTROL PAGES ON SCROLL
// ------------------------------------------------
func scrollViewDidScroll(_ scrollView: UIScrollView) {
let pageWidth = containerScrollView.frame.size.width
let page = Int(floor((containerScrollView.contentOffset.x * 2 + pageWidth) / (pageWidth * 2)))
pageControl.currentPage = page
}
}
我认为您不需要 ScrollView 和管理 Pagingnation。您需要 CollectionView 并启用分页选项 From story-bored.
拖动 Collection 在您的 ViewController 中查看。启用分页选项 来自 属性 选择器。
将 CollectionView(
leading
,trailing
,top
,bottom
) 分配给 View(leading
,trailing
,top
,bottom
)将 CollectionView 单元格拖到 CollectionView 中。调整单元格大小以填充 整个Collection视图
将 Scrollview 添加到 CollectionView 单元格中并添加 ScrollView(
leading
,trailing
,top
,bottom
) == Collection查看单元格(leading
,trailing
,top
,bottom
)在Scrollview中添加imageView并添加imageView(
leading
,trailing
,top
,bottom
) == 滚动视图 (leading
,trailing
、top
、bottom
) 并且 CollectionView cell 的宽度和高度相等。- 实现
DataSource
和Delegate
方法 For CollectionView.
为了缩放,请将以下代码添加到您的 CollectionView Cell
import UIKit
class CustomeCellCollectionViewCell: UICollectionViewCell , UIScrollViewDelegate {
@IBOutlet var imageView : UIImageView!
@IBOutlet var scrollView : UIScrollView!
override func awakeFromNib() {
super.awakeFromNib()
scrollView.delegate = self
scrollView.minimumZoomScale = 1.0
scrollView.maximumZoomScale = 6.0
}
func viewForZooming(in scrollView: UIScrollView) -> UIView? {
return feedsImageView
}
}