- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试设置 UIScrollView 但它不起作用。这可能是我的限制,但我不确定。另外,我想问一下我的代码到底好不好。我正在从头开始学习 Swift,所以任何建议都值得采纳。
这是我的代码
// SecondeMenu.swift
// Bot Tes Maths
//
// Created by lucas abijmil on 23/09/2019.
// Copyright © 2019 Lucas Abijmil. All rights reserved.
//
import Foundation
import UIKit
import CoreData
class SecondeMenu: UIViewController {
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
// Hide or not the Navigation Bar
self.navigationController?.setNavigationBarHidden(false, animated: animated)
}
override func viewDidLoad() {
super.viewDidLoad()
// Set Up the NavBar
setUpNavigationBar(button: backButton)
// Set Up the container for ChoixChapitre
setUpContainer(container: containerChoixChapitre, backgoundCo: .red, autoresizing: false)
containerChoixChapitreLabelAutoLayout()
// Set up Choix Chapitre
setUpLabelString(label: choixChapitre, text: "Choix du chapitre", textA: .center, alpha: 1, backgoundCo: .clear, autoresizing: false)
choixChapitreIntoContainer()
// Set Up Scrolling
setUpScroolView(scrooling: scrolling, autoresizing: false)
scrollingDemarcation()
}
// Declaration of our variable :
// Declaration for the backButton of the BarNavigation
private let backButton = UIBarButtonItem()
// Declaration of UIView for contain
private let containerChoixChapitre = UIView()
let test = UIView()
// Declaration of Variables for Seconde Menu (basically the name of each chapter
private let choixChapitre = UILabel()
private let scrolling = UIScrollView()
private let choixChapitreStack = UIStackView()
private let nombreReel = UILabel()
private let nombreIrationnel = UILabel()
// private let nombreReel = UILabel()
// Some functions incoming... 👨💻 (when i'm coding)
// Set up scroolView
private func setUpScroolView (scrooling : UIScrollView, autoresizing : Bool) {
scrooling.translatesAutoresizingMaskIntoConstraints = autoresizing
view.addSubview(scrooling)
}
// Set up container
private func setUpContainer (container : UIView, backgoundCo : UIColor, autoresizing : Bool) {
container.backgroundColor = backgoundCo
container.translatesAutoresizingMaskIntoConstraints = autoresizing
view.addSubview(container)
}
// Set up NavigationBar
private func setUpNavigationBar (button : UIBarButtonItem) {
// title navigation bar
self.navigationItem.title = "Menu Seconde"
// back button set tittle
button.title = "Retour"
// Connect the button to the navigationBar
self.navigationController?.navigationBar.topItem?.backBarButtonItem = button
}
// Set Up Label
private func setUpLabelString (label : UILabel, text : String, textA : NSTextAlignment, alpha : CGFloat, backgoundCo : UIColor, autoresizing : Bool) {
label.text = text
label.textAlignment = textA
label.alpha = alpha
label.backgroundColor = backgoundCo
label.translatesAutoresizingMaskIntoConstraints = autoresizing
}
private func setUpChapitreStack (stack : UIStackView, axe : NSLayoutConstraint.Axis, space : CGFloat, autoresizing : Bool) {
stack.axis = axe
stack.spacing = space
stack.translatesAutoresizingMaskIntoConstraints = autoresizing
}
private func setUpLabelForStack (label : UILabel, text : String, textA : NSTextAlignment, alpha : CGFloat, backgroundCo : UIColor) {
label.text = text
label.textAlignment = textA
label.alpha = alpha
label.backgroundColor = backgroundCo
}
// Sizing and contraints :
// Sizing the scrolling dermarcation
private func scrollingDemarcation() {
scrolling.topAnchor.constraint(equalTo: containerChoixChapitre.bottomAnchor, constant: 20).isActive = true
scrolling.bottomAnchor.constraint(equalTo : view.bottomAnchor, constant: 80).isActive = true
scrolling.trailingAnchor.constraint(equalTo: view.trailingAnchor).isActive = true
scrolling.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true
scrolling.backgroundColor = .purple
// scrolling.addSubview(choixChapitreStack)
}
// Sizing the container for choixLabel
private func containerChoixChapitreLabelAutoLayout() {
containerChoixChapitre.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true
containerChoixChapitre.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 0).isActive = true
containerChoixChapitre.heightAnchor.constraint(equalTo: view.heightAnchor, multiplier: 0.1, constant: 0).isActive = true
containerChoixChapitre.widthAnchor.constraint(equalTo: view.widthAnchor, multiplier: 1, constant: 0).isActive = true
}
// Add to the scene
// Add "Choix du chapitre"
private func choixChapitreIntoContainer() {
containerChoixChapitre.addSubview(choixChapitre)
choixChapitre.heightAnchor.constraint(equalTo: containerChoixChapitre.heightAnchor, multiplier: 1, constant: 0).isActive = true
choixChapitre.widthAnchor.constraint(equalTo: containerChoixChapitre.widthAnchor, multiplier: 1, constant : 0).isActive = true
}
}
目前,我无法滚动,但我应该可以。
感谢您的帮助🙏。
最佳答案
首先,更改ViewDidLoad中的流程
override func viewDidLoad() {
super.viewDidLoad()
// Set Up the NavBar
setUpNavigationBar(button: backButton)
// Set Up Scrolling
setUpScroolView(scrooling: scrolling, autoresizing: false)
scrollingDemarcation()
// Set Up the container for ChoixChapitre
setUpContainer(container: containerChoixChapitre, backgoundCo: .red, autoresizing: false)
containerChoixChapitreLabelAutoLayout()
// Set up Choix Chapitre
setUpLabelString(label: choixChapitre, text: "Choix du chapitre", textA: .center, alpha: 1, backgoundCo: .clear, autoresizing: false)
choixChapitreIntoContainer()
}
并将容器 View 添加到 ScrollView
// Set up container
private func setUpContainer (container : UIView, backgoundCo : UIColor, autoresizing : Bool) {
container.backgroundColor = backgoundCo
container.translatesAutoresizingMaskIntoConstraints = autoresizing
self.scrolling.addSubview(container)
}
希望这会起作用。
关于swift - 如何设置好UIScrollView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58236310/
抱歉这个奇怪的标题,但是,这正是我所需要的。我知道这是可以做到的,因为我见过其他应用程序这样做。 基本上,我的应用程序有一个启用分页的大 ScrollView ,其中包含一些嵌套的 ScrollVie
我还没有尝试过,但我假设一旦我知道用户想要在子 ScrollView 中滚动,我就必须禁用父 ScrollView 的滚动,对吗? 两个 ScrollView 都是水平滚动的。 如何暂时禁用父级的滚动
我需要实现这个方法: - (CGRect)zoomRectForScale:(float)scale withCenter:(CGPoint)center { 但我不知道如何获得我需要的中心坐标。通常
我想根据 UIAccelerometer 值滚动 ScrollView 。实现这一目标的最佳方法是什么? 最初,我根据获得的加速度计值将内容偏移设置为一个值。然后在每个 scrollViewDidEn
我有一个 UIScrollView,我需要底部淡入透明,这样它就不会突然切断内容。 UIScrollView 的背景是自定义颜色。这是我到目前为止所拥有的,但图层显示为白色,而不是自定义颜色。这就是我
我有一个 UIScrollviews 彼此存在的层次结构。 如何将特定区域的滑动事件重定向到内部 ScrollView ? 最佳答案 如果您将 UIScrollViews 设置为只能在一个轴或另一轴上
在我的应用程序中,我有一个扩展 UIScrollView 并在用户滚动时填充其内容的 View 。但是,如果用户滚动太快,则 UIScrollView 内填充的 View 不会及时创建,您实际上可以看
我有一个包含内容的 UIScroll View 。如果该内容溢出,使 ScrollView 可滚动,我想将 View 的底部设置为某种颜色。如果没有,我想将其设置为不同的颜色。 我的问题是,我不知道如
我有一个 ScrollView ,其中包含一个 UIImageView,以及一个额外的 UIScrollView 和 UIImageView。 我想要实现的是独立缩放和平移每个 ScrollView
类似的问题也有人问过这个,但我的困境其实和他们正好相反。我有一个全屏、分页 UIScrollView,每个页面都是屏幕的大小。在其中,我有一些页面本身就是 UIScrollViews,它们的宽度大于屏
我有一个 UIScrollView 和另一个 UIScrollView 。它们都水平滚动并且具有 pagingEnabled = YES。假设我开始滚动内部 ScrollView 并到达最右边界。如果
我有一个 UIScrollView,里面有一个(自定义)UIView。 在我的 scrollViewDidScroll 方法中,我正在调用 [myCustomView setNeedsDisplay]
我有一个水平滚动的 UICollectionView,其中填充了垂直滚动的 UITableViews(两者都是 UISCrollView 的子类)。当滚动手势开始沿任一方向滚动时,在其减速完成之前不会
iOS 8, swift 。我试图在水平 ScrollView 上创建垂直 ScrollView 。它们都是 UIScrollView。垂直 ScrollView 允许从底部向上滑动 View 。顶部
我需要一个分页的 UIScrollView,它以 UIScreenEdgePanGestureRecognizer 的方式检测屏幕边缘的平移,而不是像 UIPanGestureRecognizer 那
假设我有多个 ScrollView ,并且我希望在任何给定时间只打开其中一个 (scrollView.contentOffset != 0)。因此,当 scroll view 1 打开且 scroll
我在分页 UIScrollView(外部)中的 VC 中有 UIScrollView(内部 - UICollectionView 是诚实的)。两者都是水平的。当我向内滚动到边缘(左侧或右侧)时,它开始
如何在不干扰现有 UIScrollView 的情况下从现有 UIScrollView 获取重复的 UIScrollView。 第一个 ScrollView , UIScrollView *firstS
我的应用程序中有一个点,我删除了一个 ScrollView 并添加了另一个。我希望新 ScrollView 中也能出现上一个 ScrollView 中的相同手势。我尝试过: s
请告诉我如何在类似嵌套进程的 ScrollView 中设置 ScrollView 。 以下代码部分有效。 int x=10; int y=10; for(int i=0; i<5; i++) {
我是一名优秀的程序员,十分优秀!