AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 79440192
Accepted
Chris Hansen
Chris Hansen
Asked: 2025-02-15 01:49:37 +0800 CST2025-02-15 01:49:37 +0800 CST 2025-02-15 01:49:37 +0800 CST

Elementos não centralizados na página

  • 772

Eu tenho o seguinte código

    let scrollView = UIScrollView()
    scrollView.translatesAutoresizingMaskIntoConstraints = false
    scrollView.showsHorizontalScrollIndicator = false
    scrollView.showsVerticalScrollIndicator = false
    view.addSubview(scrollView)
    
    NSLayoutConstraint.activate([
        scrollView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor),
        scrollView.leadingAnchor.constraint(equalTo: view.leadingAnchor),
        scrollView.trailingAnchor.constraint(equalTo: view.trailingAnchor),
        scrollView.bottomAnchor.constraint(equalTo: view.bottomAnchor)
    ])
    
    let contentView = UIView()
    contentView.translatesAutoresizingMaskIntoConstraints = false
    scrollView.addSubview(contentView)
    
    contentView.backgroundColor = UIColor(red: 0.97, green: 0.98, blue: 0.99, alpha: 1.00)
    
    NSLayoutConstraint.activate([
        contentView.topAnchor.constraint(equalTo: scrollView.topAnchor),
        contentView.leadingAnchor.constraint(equalTo: scrollView.leadingAnchor),
        contentView.trailingAnchor.constraint(equalTo: scrollView.trailingAnchor),
        contentView.bottomAnchor.constraint(equalTo: scrollView.bottomAnchor)
    ])
    
    // Large Label
    let largeLabel: UILabel = {
        let label = UILabel()
        label.text = "Congrats!"
        label.font = UIFont(name: "Inter-Bold", size: 24)
        label.textAlignment = .center
        label.numberOfLines = 0
        label.translatesAutoresizingMaskIntoConstraints = false
        return label
    }()
    
    // Small Label
    let smallLabel: UILabel = {
        let label = UILabel()
        label.text = "Your finished the \(category.name) lesson."
        label.font = UIFont(name: "Inter-Regular", size: 16)
        label.textColor = .black
        label.textAlignment = .center
        label.numberOfLines = 0
        label.lineBreakMode = .byWordWrapping
        label.translatesAutoresizingMaskIntoConstraints = false
        return label
    }()
    
    
    // Image View
    let animatedImageView: UIImageView = {
        let imageView = UIImageView(image: UIImage(named: "fire"))
        imageView.tintColor = .systemYellow
        imageView.contentMode = .scaleAspectFit
        imageView.translatesAutoresizingMaskIntoConstraints = false
        return imageView
    }()
    
    
    contentView.addSubview(largeLabel)
    contentView.addSubview(smallLabel)
    contentView.addSubview(animatedImageView)
    
    
    let totalScore = score + WUser.sharedInstance.getUserScore()
    var nextLevel = ""
    var currentLevel = ""
    var toXP = 0
    
    let pointsView = UIView()
    pointsView.layer.cornerRadius = 20
    pointsView.backgroundColor = .white
    pointsView.layer.borderColor = UIColor.gray.cgColor
    pointsView.layer.borderWidth = 1
    pointsView.layer.masksToBounds = true
    pointsView.translatesAutoresizingMaskIntoConstraints = false
    contentView.addSubview(pointsView)
    
    let pointsLabel: UILabel = {
        let label = UILabel()
        label.text = "Points Earned"
        label.font = UIFont(name: "Inter-Bold", size: 16)
        label.translatesAutoresizingMaskIntoConstraints = false
        return label
    }()
    
    let percentageLabel: UILabel = {
        let label = UILabel()
        label.text = "+\(score + 5)"
        label.font = UIFont(name: "Inter-Bold", size: 16)
        label.translatesAutoresizingMaskIntoConstraints = false
        return label
    }()
    
    let iconImageView: UIImageView = {
        let imageView = UIImageView()
        imageView.contentMode = .scaleAspectFit
        imageView.image = UIImage(systemName: "star.fill")
        imageView.tintColor = UIColor(red: 0.63, green: 0.14, blue: 0.92, alpha: 1.00)
        imageView.translatesAutoresizingMaskIntoConstraints = false
        return imageView
    }()
       
    let progressView = UIProgressView(progressViewStyle: .default)
    progressView.progress = 0
    progressView.layer.cornerRadius = 10
    progressView.layer.masksToBounds = true
    progressView.trackTintColor = UIColor(red: 0.91, green: 0.91, blue: 0.91, alpha: 1.00)
    progressView.progressTintColor = UIColor(red: 0.63, green: 0.14, blue: 0.92, alpha: 1.00)
    progressView.translatesAutoresizingMaskIntoConstraints = false

    
    if totalScore < 5 {
        currentLevel = "Level 1"
        nextLevel = "Starter"
        toXP = 5 - totalScore
    } else if totalScore < 50 {
        currentLevel = "Starter"
        nextLevel = "Trailblazer"
        toXP = 50 - totalScore
    } else if totalScore < 100 {
        currentLevel = "Trailblazer"
        nextLevel = "Champ"
        toXP = 100 - totalScore
    } else if totalScore < 200 {
        currentLevel = "Champ"
        nextLevel = "Genius"
        toXP = 200 - totalScore
    } else if totalScore < 500 {
        currentLevel = "Champ"
        nextLevel = "Genius"
        toXP = 500 - totalScore
    } else {
        currentLevel = "Genius"
        nextLevel = "Genius"
    }
    
    
    let xpLabel: UILabel = {
        let label = UILabel()
        label.text = "\(toXP) XP to \(nextLevel)"
        label.font = UIFont(name: "Inter-Regular", size: 14)
        label.translatesAutoresizingMaskIntoConstraints = false
        return label
    }()
    
    pointsView.addSubview(pointsLabel)
    pointsView.addSubview(percentageLabel)
    pointsView.addSubview(iconImageView)
    contentView.addSubview(progressView)
    contentView.addSubview(xpLabel)
    
    NSLayoutConstraint.activate([
        largeLabel.topAnchor.constraint(equalTo: contentView.safeAreaLayoutGuide.topAnchor, constant: 20),
        largeLabel.leadingAnchor.constraint(equalTo: contentView.leadingAnchor, constant: 20),
        largeLabel.trailingAnchor.constraint(equalTo: contentView.trailingAnchor, constant: -20),
        
        // Small Label Constraints
        smallLabel.topAnchor.constraint(equalTo: largeLabel.bottomAnchor, constant: 20),
        smallLabel.leadingAnchor.constraint(equalTo: contentView.leadingAnchor, constant: 20),
        smallLabel.trailingAnchor.constraint(equalTo: contentView.trailingAnchor, constant: -20),
        
        animatedImageView.topAnchor.constraint(equalTo: smallLabel.bottomAnchor, constant: 40),
        animatedImageView.centerXAnchor.constraint(equalTo: contentView.centerXAnchor),
        animatedImageView.widthAnchor.constraint(equalToConstant: 150),
        animatedImageView.heightAnchor.constraint(equalToConstant: 150),
            
        pointsView.topAnchor.constraint(equalTo: animatedImageView.bottomAnchor, constant: 50),
        pointsView.widthAnchor.constraint(equalToConstant: 300),
        pointsView.heightAnchor.constraint(equalToConstant: 50),
        pointsView.centerXAnchor.constraint(equalTo: contentView.centerXAnchor),
        
        pointsLabel.leadingAnchor.constraint(equalTo: pointsView.leadingAnchor, constant: 16),
        pointsLabel.centerYAnchor.constraint(equalTo: pointsView.centerYAnchor),
        
        percentageLabel.trailingAnchor.constraint(equalTo: iconImageView.leadingAnchor, constant: -8),
        percentageLabel.centerYAnchor.constraint(equalTo: pointsView.centerYAnchor),
        
        iconImageView.trailingAnchor.constraint(equalTo: pointsView.trailingAnchor, constant: -16),
        iconImageView.centerYAnchor.constraint(equalTo: pointsView.centerYAnchor),
        iconImageView.widthAnchor.constraint(equalToConstant: 24),
        iconImageView.heightAnchor.constraint(equalToConstant: 24),
        
        
        progressView.leadingAnchor.constraint(equalTo: pointsView.leadingAnchor, constant: 16),
        progressView.trailingAnchor.constraint(equalTo: pointsView.trailingAnchor, constant: -16),
        progressView.topAnchor.constraint(equalTo: pointsView.bottomAnchor, constant: 30),
        progressView.heightAnchor.constraint(equalToConstant: 20),
        
        xpLabel.leadingAnchor.constraint(equalTo: progressView.leadingAnchor),
        xpLabel.topAnchor.constraint(equalTo: progressView.bottomAnchor, constant: 10)
    ])
    
    
    let instructionLabel = UILabel()
    instructionLabel.text = "How would you rate the lesson?"
    instructionLabel.textAlignment = .center
    instructionLabel.font = UIFont(name: "Inter-Bold", size: 18)
    instructionLabel.translatesAutoresizingMaskIntoConstraints = false
    
    let starsStackView = UIStackView()
    starsStackView.axis = .horizontal
    starsStackView.alignment = .center
    starsStackView.distribution = .equalSpacing
    starsStackView.spacing = 10
    starsStackView.translatesAutoresizingMaskIntoConstraints = false
    
    for i in 1...5 {
        let button = UIButton(type: .system)
        button.tag = i
        button.setTitle("★", for: .normal)
        button.titleLabel?.font = UIFont.systemFont(ofSize: 30)
        button.setTitleColor(.lightGray, for: .normal)
        button.addTarget(self, action: #selector(starTapped(_:)), for: .touchUpInside)
        starsStackView.addArrangedSubview(button)
    }
    
    let submitButton = UIButton(type: .system)
    submitButton.setTitle("Submit Rating", for: .normal)
    submitButton.backgroundColor = UIColor(red: 0.35, green: 0.25, blue: 0.55, alpha: 1.00)
    submitButton.setTitleColor(.white, for: .normal)
    submitButton.layer.cornerRadius = 20
    submitButton.titleLabel?.font = UIFont(name: "Inter-Bold", size: 16)
    submitButton.addTarget(self, action: #selector(submitRating), for: .touchUpInside)
    submitButton.translatesAutoresizingMaskIntoConstraints = false
    
    
    let closeButton = UIButton(type: .system)
    closeButton.setTitle("Close", for: .normal)
    closeButton.setTitleColor(.gray, for: .normal)
    closeButton.titleLabel?.font = UIFont(name: "Inter-Bold", size: 16)
    closeButton.addTarget(self, action: #selector(goBack), for: .touchUpInside)
    closeButton.translatesAutoresizingMaskIntoConstraints = false
    
    contentView.addSubview(instructionLabel)
    contentView.addSubview(starsStackView)
    contentView.addSubview(submitButton)
    contentView.addSubview(closeButton)
    
    NSLayoutConstraint.activate([
        instructionLabel.topAnchor.constraint(equalTo: xpLabel.bottomAnchor, constant: 30),
        instructionLabel.centerXAnchor.constraint(equalTo: contentView.centerXAnchor),
        
        starsStackView.topAnchor.constraint(equalTo: instructionLabel.bottomAnchor, constant: 20),
        starsStackView.centerXAnchor.constraint(equalTo: contentView.centerXAnchor),
        
        submitButton.topAnchor.constraint(equalTo: starsStackView.bottomAnchor, constant: 20),
        submitButton.widthAnchor.constraint(equalToConstant: 250),
        submitButton.heightAnchor.constraint(equalToConstant: 50),
        submitButton.centerXAnchor.constraint(equalTo: contentView.centerXAnchor),
        
        
        closeButton.topAnchor.constraint(equalTo: submitButton.bottomAnchor, constant: 20),
        closeButton.widthAnchor.constraint(equalToConstant: 250),
        closeButton.heightAnchor.constraint(equalToConstant: 50),
        closeButton.centerXAnchor.constraint(equalTo: contentView.centerXAnchor),
        closeButton.bottomAnchor.constraint(equalTo: contentView.bottomAnchor, constant: -20.0)
    ])
    
    
    DispatchQueue.main.asyncAfter(deadline: .now() + 0.5) {
        UIView.animate(withDuration: 1.5) {
            progressView.setProgress(Float(Float(totalScore)/500), animated: true)
        }
    }
    
    UIView.animate(withDuration: 1.0,
                   delay: 0,
                   options: [.autoreverse, .repeat],
                   animations: {
        animatedImageView.transform = CGAffineTransform(scaleX: 1.5, y: 1.5)
    }, completion: { _ in
        animatedImageView.transform = .identity
    })

Infelizmente, os elementos não são centralizados na página. Eles se deslocam para a esquerda da tela.

Veja em anexo

Alguém pode ajudar, por favor?

insira a descrição da imagem aqui

  • 2 2 respostas
  • 40 Views

2 respostas

  • Voted
  1. DonMag
    2025-02-15T03:04:37+08:002025-02-15T03:04:37+08:00

    Você precisa informar à sua "visualização de conteúdo" qual deve ser a largura dela.

    Adicione esta restrição:

    contentView.widthAnchor.constraint(equalTo: scrollView.frameLayoutGuide.widthAnchor)
    

    Dicas para casais:

    • Aprenda a usarDebug View Hierarchy
    • dê aos seus elementos da IU cores de fundo contrastantes, para que você possa ver o enquadramento
    • 1
  2. Best Answer
    Kiryl Famin
    2025-02-15T03:25:40+08:002025-02-15T03:25:40+08:00

    Tenho quase certeza de que parece assim porque as âncoras do contentView não estão configuradas corretamente. No seu código, você tem esta restrição:

    contentView.trailingAnchor.constraint(equalTo: scrollView.trailingAnchor)
    

    Isso significa que a borda direita de contentView é fixada na borda direita de scrollView, mas não garante que contentView sempre corresponderá à largura de scrollView.

    Se o conteúdo de contentView expandir além de scrollView.width, scrollView permitirá rolagem horizontal. Se o conteúdo de contentView for menor que scrollView.width, contentView não será esticado automaticamente, e o conteúdo pode não aparecer alinhado corretamente à direita.

    A maneira correta de configurar restrições é

    NSLayoutConstraint.activate([
        contentView.topAnchor.constraint(equalTo: scrollView.topAnchor),
        contentView.leadingAnchor.constraint(equalTo: scrollView.leadingAnchor),
                contentView.widthAnchor.constraint(equalTo: scrollView.widthAnchor),
        contentView.bottomAnchor.constraint(equalTo: scrollView.bottomAnchor)
    ])
    
    • 1

relate perguntas

  • Adicionar número de série para atividade de cópia ao blob

  • A fonte dinâmica do empacotador duplica artefatos

  • Selecione linhas por grupo com 1s consecutivos

  • Lista de chamada de API de gráfico subscritoSkus estados Privilégios insuficientes enquanto os privilégios são concedidos

  • Função para criar DFs separados com base no valor da coluna

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve