- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在将项目添加到 ScrollView 时遇到了一些问题。现在我已经以编程方式将所有项目添加到 ScrollView 中,但遇到了一些自动布局问题。我不完全理解如何在不执行我正在做的所有编程的情况下将项目添加到 ScrollView 中,或者至少通过添加某种形式的自动布局来使其在不同设备上看起来不会那么糟糕。如果你能帮忙,请告诉我。我的代码如下。
提前致谢!
附言文本字段添加到一个单独的函数中。
附言有些图像是文本,但它们被用作图像,因为您无法在 iOS 中设置它们的格式以获得我想要的外观。
/*
ManagePages - This section handles the UIScrollView
*/
private func managePages()
{
self.sideScrollView.frame = CGRect(x:0, y:0, width:self.view.frame.width, height:self.view.frame.height)
let scrollViewWidth:CGFloat = self.sideScrollView.frame.width
let scrollViewHeight:CGFloat = self.sideScrollView.frame.height
let imgOne = UIImageView(frame: CGRect(x:(scrollViewWidth/2) - (129/2), y:157,width:129, height:84))
imgOne.image = UIImage(named: "Image1")
imgOne.contentMode = .scaleAspectFit
let imgTwo = UIImageView(frame: CGRect(x:((((scrollViewWidth*2)/4))*3)-(153/2), y:137,width:153, height:153))
imgTwo.image = UIImage(named: "Image2")
imgOne.contentMode = .scaleAspectFit
let imgThree = UIImageView(frame: CGRect(x:((((scrollViewWidth*3)/6))*5)-(132/2), y:137,width:132, height:151))
imgThree.image = UIImage(named: "Image3")
imgOne.contentMode = .scaleAspectFit
let imgFour = UIImageView(frame: CGRect(x:((((scrollViewWidth*4)/8))*7)-(139/2), y:137,width:139, height:118))
imgFour.image = UIImage(named: "Image4")
imgOne.contentMode = .center
let imgFive = UIImageView(frame: CGRect(x:((((scrollViewWidth*5)/10))*9)-(171/2), y:127,width:171, height:169))
imgFive.image = UIImage(named: "Image5")
imgOne.contentMode = .scaleAspectFit
let imgSix = UIImageView(frame: CGRect(x:((((scrollViewWidth*6)/12))*11)-(133/2), y:127,width:133, height:175))
imgSix.image = UIImage(named: "Image6")
imgSix.contentMode = .scaleAspectFit
let messageOne = UIImageView(frame: CGRect(x: 0, y: (137+153+25), width: scrollViewWidth, height: 112))
messageOne.image = UIImage(named: "Message1")
messageOne.contentMode = .scaleAspectFit
let titleOne = UIImageView(frame: CGRect(x: (scrollViewWidth/2) - (131/2), y:57, width: 131, height: 56))
titleOne.image = UIImage(named: "Title1")
titleOne.contentMode = .scaleAspectFit
let titleTwo = UIImageView(frame: CGRect(x:(((scrollViewWidth*2)/4)*3)-(184/2), y: 57, width:184, height: 56))
titleTwo.image = UIImage(named: "Title2")
titleTwo.contentMode = .scaleAspectFit
let titleThree = UIImageView(frame: CGRect(x:(((scrollViewWidth*3)/6)*5)-(227/2), y: 57, width:227, height: 56))
titleThree.image = UIImage(named: "Title3")
titleThree.contentMode = .scaleAspectFit
let titleFour = UIImageView(frame: CGRect(x:(((scrollViewWidth*4)/8)*7)-(scrollViewWidth/2), y: 57, width:scrollViewWidth, height: 56))
titleFour.image = UIImage(named: "Title4")
titleFour.contentMode = .scaleAspectFit
let titleFive = UIImageView(frame: CGRect(x:(((scrollViewWidth*5)/10)*9)-(270/2), y: 57, width:270, height: 56))
titleFive.image = UIImage(named: "Title5")
titleFive.contentMode = .scaleAspectFit
let titleSix = UIImageView(frame: CGRect(x:(((scrollViewWidth*6)/12)*11)-(270/2), y: 57, width:270, height: 56))
titleSix.image = UIImage(named: "Title6")
titleSix.contentMode = .scaleAspectFit
for (index,element) in inputFields.enumerated()
{
if(index == 0)
{
element.frame = CGRect(x: calculateTextFieldXLocation(pageNumber: 1, scrollWidth: scrollViewWidth, width: 244), y: 222, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.keyboardType = .emailAddress
element.autocapitalizationType = .none
element.placeholder = "Email"
element.contentMode = .scaleAspectFit
}
else if(index == 1)
{
element.frame = CGRect(x: calculateTextFieldXLocation(pageNumber: 1, scrollWidth: scrollViewWidth, width: 244), y: 327, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.isSecureTextEntry = true
element.placeholder = "Password"
element.contentMode = .scaleAspectFit
element.returnKeyType = .done
}
else if(index == 2)
{
element.frame = CGRect(x: calculateTextFieldXLocation(pageNumber: 2, scrollWidth: scrollViewWidth, width: 244), y: 222, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.placeholder = "First Name"
element.contentMode = .scaleAspectFit
element.returnKeyType = .done
}
else if(index == 3)
{
element.frame = CGRect(x: calculateTextFieldXLocation(pageNumber: 2, scrollWidth: scrollViewWidth, width: 244), y: 327, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.placeholder = "Last Name"
element.contentMode = .scaleAspectFit
element.returnKeyType = .done
}
else if(index == 4)
{
element.frame = CGRect(x: (scrollViewWidth*3)-(scrollViewWidth/2)-(122), y: 432, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.placeholder = "Date of Birth"
element.contentMode = .scaleAspectFit
addDatePicker(element: element)
}
else if(index == 5)
{
element.frame = CGRect(x: (scrollViewWidth*3)-(scrollViewWidth/2)-(122), y: 534, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.placeholder = "Gender"
element.contentMode = .scaleAspectFit
element.inputView = genderPicker
}
else if(index == 6)
{
element.frame = CGRect(x: (scrollViewWidth*4)-(scrollViewWidth/2)-(122), y: 222, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.placeholder = "Favorite Type"
element.contentMode = .scaleAspectFit
element.inputView = typePicker
}
else if(index == 7)
{
element.frame = CGRect(x: (scrollViewWidth*4)-(scrollViewWidth/2)-(122), y: 327, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.placeholder = "Eye Color"
element.contentMode = .scaleAspectFit
element.inputView = colorPicker
}
else if(index == 8)
{
element.frame = CGRect(x: (scrollViewWidth*4)-(scrollViewWidth/2)-(122), y: 432, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.placeholder = "Height"
element.contentMode = .scaleAspectFit
element.returnKeyType = .done
}
else if(index == 9)
{
element.frame = CGRect(x: (scrollViewWidth*4)-(scrollViewWidth/2)-(122), y: 534, width: 244, height: 49)
element.background = UIImage(named:"SetupTextField")
element.font = UIFont(name: "System", size: 24.0)
element.textAlignment = .center
element.placeholder = "Weight"
element.contentMode = .scaleAspectFit
element.keyboardType = .decimalPad
element.returnKeyType = .done
}
}
let swipeArrow = UIImageView(frame: CGRect(x:(scrollViewWidth/2)-(170/2), y: scrollViewHeight-120, width:170, height: 60))
swipeArrow.image = UIImage(named: "WelcomeSwipeToContinue")
swipeArrow.contentMode = .scaleAspectFit
let getStartedButton = UIButton(frame: CGRect(x:((scrollViewWidth*5) + scrollViewWidth/2)-125, y: scrollViewHeight-175, width: 250, height: 99))
getStartedButton.setImage(UIImage(named: "GetStartedButton"), for: UIControlState.normal)
getStartedButton.addTarget(self, action: #selector(finishSetup), for: .touchUpInside)
self.sideScrollView.addSubview(imgOne)
self.sideScrollView.addSubview(messageOne)
self.sideScrollView.addSubview(titleOne)
self.sideScrollView.addSubview(titleTwo)
self.sideScrollView.addSubview(titleThree)
self.sideScrollView.addSubview(titleFour)
self.sideScrollView.addSubview(titleFive)
self.sideScrollView.addSubview(titleSix)
self.sideScrollView.addSubview(swipeArrow)
for fieldName in inputFields
{
self.sideScrollView.addSubview(fieldName)
}
self.sideScrollView.addSubview(getStartedButton)
self.sideScrollView.contentSize = CGSize(width:self.sideScrollView.frame.width * 6, height:self.sideScrollView.frame.height)
self.sideScrollView.delegate = self
//self.pageControl.currentPage = 0
}
最佳答案
使用 scrollView
的最简单方法是在 scrollView
中添加一个 UIView
(将其命名为 contentView
).然后将所有内容放入此 contentView
中。您的所有约束都将基于 contentView
。然后你所要做的就是操纵contentView
的frame来调整scrollView
关于ios - Swift - 如何对 ScrollView 中的项目使用自动布局?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43531750/
我为 S3 做了一个额外的布局(所有布局的反叛),人们说,使用 layout-sw320dp 对 s3 有好处。一切正常,s3 选择了这个文件夹,布局在 s3 上看起来很棒。 但是当我尝试在 10"平
我是 CSS 的新手,我正在尝试创建一个 3 列布局。也应该有一个居中的页脚。页面的总高度应该填满当前的屏幕。宽度似乎不对。 目前,页脚在尺寸和位置上似乎都没有对齐。 I have attached
已关闭。这个问题是 off-topic 。目前不接受答案。 想要改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 已关闭10 年前。 Improve th
有没有办法确定设备是从右到左的语言(比如阿拉伯语)而不是从左到右的语言(英语)? 需要与旧 API 级别(低至 10)兼容的东西 解决方案 我最终在接受的答案中使用了 xml 方法。更进一步,我还添加
我是 QT 的新手。我试图通过实现下面看到的这个小窗口来理解布局机制。它在作为主窗口的 QWidget 下具有以下元素: 一个延伸到所有客户区域的大型 QWidget。 窗口顶部的两个 QWidget
Accordion 布局是堆叠面板布局,因为此时只有一个面板可见,但我想同时显示两个面板可见,所以我们可以使用 Accordion 面板来做到这一点吗?? 最佳答案 您不能扩展现有的 Accordio
我只是想知道,作为一个假设示例,针对以下场景布局表格的最佳方式是什么: 假设我正在编写一个用于跟踪学生出勤的应用程序。每年年初,我都想添加所有学生(我将手动执行此操作 - 现在,是否应该为这里的每个学
在 CVS 中,我们的项目中有多个目录。 有一个夜间构建,它必须从同一个 CVS 项目的不同目录中提取东西才能构建夜间构建。所以我应该记住这一点,如果我们迁移到 SVN,我必须修改构建脚本以从不同的存
我在 WPF Windows 上有几个列表框,带有 Height="Auto" Width="Auto"在表格上设置 表单大小在不同分辨率下完美匹配,但问题是当我按下最大化按钮时,在表单调整大小时会看
仅供引用,我是 WPF 的新手。 我正在我的 WPF 应用程序中创建一个侧边栏并想要圆角。我学到的不是可以附加到网格的属性。另外,我尝试将文本块放在边框控件中,但我收到的错误消息说“ child 只能
我是CodeIgniter的新手。我想使用包含菜单,页脚等的基本样式创建母版页或布局。我不想在所有页面中编写重复的内容并为所有页面自动加载。例如,我可以在asp.net中创建母版页,或者在asp.ne
我正在使用它来调试应用程序。调试的时候发现底部显示了一个窗口中变量的值,如图- 但是,当我显示表达式时,我得到这样的布局 - 我的问题是,是否可以更改变量窗口的布局也可以在右侧显示值,因为这对我来说很
上面的代码中,放置“as=”footer_links”是什么意思? 最佳答案 as="x" 语法定义模板可用来调用 block 的名称。因此,对于以下内容: 在outer_block.p
我试图编写一个检查注册表值的功能,以查看Windows上的控制台是否启用了颜色。 Computer\HKEY_CURRENT_USER\Console\VirtualTerminalLevel 如果您
我有一个布局,但无法提前定义其所有区域,因为它们是未知的。 稍后创建了 ItemView,我想使用 View 的 ID 作为区域名称在布局中创建一个新区域,这样我就可以说: layout.dynami
我们有一个相当复杂的 gulp 构建过程,涉及多个模块,每个模块都有一个或两个 watch 。我想在一个仪表板中监控这一点,如下所示: 每一列都是一个模块,列内的每一行都是后续的构建步骤。一旦第 1
这就是问题所在,我有一个 MainWindow 类,它在一个设置例程中扩展了 JFrame,我将该类的布局设置为新的 CardLayout()。这一切都工作正常,但是当我从 JFrame 请求布局并将
我正在制作一个简单的迷宫程序,用户可以在其中创建墙壁、路径、起点和终点,单击“解决”,迷宫将被解决。为此,我有一个大小为 640x480 的 java JFrame。在 JFrame 的左侧,我有一个
我正在使用它来调试应用程序。调试的时候发现底部显示了一个窗口中变量的值,如图- 但是,当我显示表达式时,我得到这样的布局 - 我的问题是,是否可以更改变量窗口的布局也可以在右侧显示值,因为这对我来说很
我已经编写了使用 VBox 作为布局的代码。我希望按钮出现在顶行,然后绘制 2 条水平线,在 400x400 场景中应位于 y=200 和 300 处。但输出显示了我给出的不同坐标处的线条。 我知道这
我是一名优秀的程序员,十分优秀!