0

我有:

  1. UIView(容器)
  2. 界面视图。(1) 的子视图 - 下图中的深蓝色
  3. 界面视图。(1) 的子视图 - 下图中的紫色
  4. UIL标签。edge.equalToSuperview()

我要完成的工作:

我想要完成的事情

问题是,我希望 UILabel 旋转 3pi/2 (270°)。一旦我完成了旋转,它就没有正确放置。

这是通过设置 edges.equalToSuperview() 和 270°旋转后的样子: 这就是旋转和边缘的外观。equalToSuperview()

我试过这个(但它会导致崩溃):

myLabel.makeConstraints { make in
    make.top.equalTo(containerView.snp.left)
    make.right.equalTo(containerView.snp.top)
    make.left.equalTo(containerView.snp.bottom)
    make.bottom.equalTo(containerView.snp.right)
}

崩溃描述:

*** Terminating app due to uncaught exception 'NSInvalidLayoutConstraintException', reason: 'Constraint improperly relates anchors of incompatible types: <SnapKit.LayoutConstraint:0x6100000ad8c0@MyClass.swift#250 MyProject.MyLabel:0x7fcc2201ca80.top == UIView:0x7fcc2201bd30.left>'

有什么想法我可以在这里做什么吗?

4

2 回答 2

1

我已经使用默认的自动布局完成了它,我也非常喜欢。:)

这是功能。

func makeLabel() {
        //Creating stackview
        let stackView = UIStackView()
        view.addSubview(stackView)
        stackView.translatesAutoresizingMaskIntoConstraints = false
        stackView.alignment = .fill
        stackView.distribution = .fillEqually
        stackView.axis = .vertical

        //Creating blueView
        let blueView = UIView()
        blueView.backgroundColor = UIColor.darkGray
        blueView.translatesAutoresizingMaskIntoConstraints = false
        stackView.addArrangedSubview(blueView)
        blueView.widthAnchor.constraint(equalToConstant: 100).isActive = true

        //Creating purpleView
        let purpleView = UIView()
        purpleView.backgroundColor = UIColor.purple
        purpleView.translatesAutoresizingMaskIntoConstraints = false
        stackView.addArrangedSubview(purpleView)

        stackView.leadingAnchor.constraint(equalTo: view.leadingAnchor, constant: 0).isActive = true
        stackView.topAnchor.constraint(equalTo: view.topAnchor, constant: 0).isActive = true
        stackView.bottomAnchor.constraint(equalTo: view.bottomAnchor, constant: 0).isActive = true

        //Creating rotated label
        let label = UILabel()
        view.addSubview(label)
        label.transform = CGAffineTransform.init(rotationAngle: -CGFloat.pi/2)
        label.textColor = UIColor.white
        label.text = "This is my Rotated Text"
        label.font = UIFont.systemFont(ofSize: 25)
        label.translatesAutoresizingMaskIntoConstraints = false
        label.centerXAnchor.constraint(equalTo: stackView.centerXAnchor, constant: 0).isActive = true
        label.centerYAnchor.constraint(equalTo: stackView.centerYAnchor, constant: 0).isActive = true


    }

这是输出。

肖像:

在此处输入图像描述

景观

在此处输入图像描述

于 2017-06-12T21:15:32.033 回答
1

对于任何对使用 Snapkit 对 elk_cloner 的回答感兴趣的人:

myLabel.snp.makeConstraints { make in
    make.centerX.equalTo(containerView.snp.centerX)
    make.centerY.equalTo(containerView.snp.centerY)
}
于 2017-06-12T21:30:23.183 回答