自定义 UIPageControl 的位置

Posted

技术标签:

【中文标题】自定义 UIPageControl 的位置【英文标题】:Customise Position of UIPageControl 【发布时间】:2014-07-24 12:12:50 【问题描述】:

我正在使用来自 github 的项目作为参考。

项目网址:

https://github.com/lephuocdai/iossample/tree/master/PageViewDemo

在这个项目中,我想在左上角显示 UIPageControl。

我尝试使用 CGRectMake() 将 pageControl 的 rect 属性设置为某个值;但它始终显示在底部中心

【问题讨论】:

【参考方案1】:

这是一种非常简洁且 100% 有效的方法来更改 pageControl 的位置

extension UIPageViewController 
  override open func viewDidLayoutSubviews() 
      super.viewDidLayoutSubviews()

      for subV in self.view.subviews 
          if type(of: subV).description() == "UIPageControl" 
              let pos = CGPoint(x: newX, y: newY)
              subV.frame = CGRect(origin: pos, size: subV.frame.size)
          
      
  

【讨论】:

【参考方案2】:

该项目使用 UIPageViewController 来处理内容的显示和移动。 您可以向该对象提供数据,以便它按您所说的那样显示 UIPageControl。 但是除了一些颜色样式之外,您无法控制该项目的显示。 如果你想定位它,你需要实现你自己的 UIPageControl 实例并手动处理它的内容、位置和变化。

【讨论】:

自己的 UIPageControl 实例,你能给出一些想法吗,或者我需要实现全新的;我已将此演示转换为 swift 如果你想在这个项目中使用页面控件并移动它的框架,禁用自动生成的 UIPageViewController,然后建立你自己的,将它添加到视图控制器视图并提供它启动时和每次检测到 UIPageViewController 中的滑动时计数和索引值【参考方案3】:

覆盖pageviewcontroller的viewDidLayoutSubviews()并使用这个

override func viewDidLayoutSubviews() 
    super.viewDidLayoutSubviews()

    // get pageControl and scroll view from view's subviews
    let pageControl = view.subviews.filter $0 is UIPageControl .first! as! UIPageControl
    let scrollView = view.subviews.filter $0 is UIScrollView .first! as! UIScrollView
    // remove all constraint from view that are tied to pagecontrol
    let const = view.constraints.filter  $0.firstItem as? NSObject == pageControl || $0.secondItem as? NSObject == pageControl 
    view.removeConstraints(const)

    // customize pagecontroll
    pageControl.translatesAutoresizingMaskIntoConstraints = false
    pageControl.addConstraint(pageControl.heightAnchor.constraintEqualToConstant(35))
    pageControl.backgroundColor = view.backgroundColor

    // create constraints for pagecontrol
    let leading = pageControl.leadingAnchor.constraintEqualToAnchor(view.leadingAnchor)
    let trailing = pageControl.trailingAnchor.constraintEqualToAnchor(view.trailingAnchor)
    let bottom = pageControl.bottomAnchor.constraintEqualToAnchor(scrollView.topAnchor, constant:8) // add to scrollview not view

    // pagecontrol constraint to view
    view.addConstraints([leading, trailing, bottom])
    view.bounds.origin.y -= pageControl.bounds.maxY

【讨论】:

【参考方案4】:

您的页面控件是否包含在其他视图中,如果是,那么您可能设置了错误的坐标,请尝试将您的页面 control.frame 的日志放在其中以了解它的位置

【讨论】:

【参考方案5】:

如果使用故事板,请使用右下角的菜单放置一个 UIPageControl 对象并设置约束。

如果使用框架,只需以编程方式添加:

var pageControl = UIPageControl()
pageControl.frame = CGRectMake(0,0,0,0) <- These are the coordinates.
self.view.addSubView(pageControl)

【讨论】:

【参考方案6】:

如果你为 UIPageControl 设置了框架,它就不起作用。 除此之外,您可以设置转换。

[_pageControl setTransform:CGAffineTransformMakeTranslation(100, 0.0)];

享受编码

【讨论】:

以上是关于自定义 UIPageControl 的位置的主要内容,如果未能解决你的问题,请参考以下文章

带有点图像的自定义 UIPageControl

自定义 UIPageControl 点在加载时错位

UIPageControl 自定义类 - 发现 nil 将图像更改为点

具有 UIPageControl 性能问题的自定义 UIScrollview

UIPageControl 自定义样式 Nat Geo

如何在 iOS 4 中调整 UIPageControl 的指标?