Мне нужна небольшая помощь в этом виде.на практике я бы хотел уменьшить зеленую кнопку по высоте.Я пытался исправить это различными способами, но либо вылетает приложение, либо они не работают.
Может кто-нибудь сказать мне, как решить?
Снимок экрана проблемного представления:
программно на данный момент здесь.Зеленая часть, которую я должен уменьшить по высоте, называется "buttonShare"
private extension DropPreviewView {
struct Constants {
static let regionSpan: CLLocationDistance = 250
static let cornerRadius: CGFloat = 10
static let headerHeight: CGFloat = 60
}
func setupUI() {
buttonShare.do {
$0.backgroundColor = .green
$0.addTarget(self, action: #selector(didTapOutsideView), for: .touchUpInside)
}
blurredBackgroundView.do {
$0.effect = UIBlurEffect(style: .dark)
let tapGestureRecognizer = UITapGestureRecognizer(target: self, action: #selector(didTapOutsideView))
$0.addGestureRecognizer(tapGestureRecognizer)
}
spinner.do {
$0.hidesWhenStopped = true
$0.color = .darkGray
$0.startAnimating()
}
contentView.do {
$0.backgroundColor = .white
$0.clipsToBounds = true
$0.layer.cornerRadius = Constants.cornerRadius
}
dropPreviewImageView.do {
$0.contentMode = .scaleAspectFill
$0.clipsToBounds = true
$0.isUserInteractionEnabled = true
let tapGestureRecognizer = UITapGestureRecognizer(target: self, action: #selector(didTapOnPreviewImage))
$0.addGestureRecognizer(tapGestureRecognizer)
}
}
func arrangeSubviews() {
addSubview(blurredBackgroundView, constraints: [
blurredBackgroundView.topAnchor.constraint(equalTo: topAnchor),
blurredBackgroundView.leftAnchor.constraint(equalTo: leftAnchor),
blurredBackgroundView.bottomAnchor.constraint(equalTo: bottomAnchor),
blurredBackgroundView.rightAnchor.constraint(equalTo: rightAnchor),
])
addSubview(contentView, constraints: [
contentView.widthAnchor.constraint(equalTo: widthAnchor, multiplier: 0.8),
contentView.heightAnchor.constraint(equalTo: heightAnchor, multiplier: 0.7),
contentView.centerXAnchor.constraint(equalTo: centerXAnchor),
contentView.centerYAnchor.constraint(equalTo: centerYAnchor),
])
addSubview(buttonShare, constraints: [
buttonShare.centerXAnchor.constraint(equalTo: centerXAnchor)
])
header.addConstraint(
header.heightAnchor.constraint(equalToConstant: Constants.headerHeight)
)
let innerStack = UIStackView(arrangedSubviews: [dropPreviewImageView, buttonShare]).then {
$0.distribution = .fillEqually
$0.axis = .vertical
$0.spacing = 10
}
let stackView = UIStackView(arrangedSubviews: [header, innerStack, buttonShare]).then {
$0.axis = .vertical
$0.distribution = .fill
$0.spacing = 10
}
contentView.addSubview(stackView, constraints: [
stackView.topAnchor.constraint(equalTo: contentView.layoutMarginsGuide.topAnchor),
stackView.leftAnchor.constraint(equalTo: contentView.layoutMarginsGuide.leftAnchor),
stackView.bottomAnchor.constraint(equalTo: contentView.layoutMarginsGuide.bottomAnchor),
stackView.rightAnchor.constraint(equalTo: contentView.layoutMarginsGuide.rightAnchor),
])
dropPreviewImageView.addSubview(spinner, constraints: [
spinner.centerXAnchor.constraint(equalTo: dropPreviewImageView.centerXAnchor),
spinner.centerYAnchor.constraint(equalTo: dropPreviewImageView.centerYAnchor),
])
}