以编程方式创建与点击按钮关联的标签

Posted

技术标签:

【中文标题】以编程方式创建与点击按钮关联的标签【英文标题】:Create label associated with buttons on clicks programmatically 【发布时间】:2017-12-16 06:36:03 【问题描述】:

假设我有一个文本字段和按钮。 有一个 IBaction 与按钮和文本字段相关联。

单击按钮时,它将创建一个标签,其中包含在文本字段中键入的文本。同时在标签字段旁边创建按钮。 (如播放或暂停按钮)

添加静态元素很容易,只需拖放即可。 但我不知道如何通过布局和约束以编程方式添加这些 UI 元素。

请告诉我更多信息或提供一些链接给我。

【问题讨论】:

【参考方案1】:

应该有多种方法来实现您的目标。以下是如何将包含标签和按钮以及约束的子视图添加到子视图的示例。默认的textFieldbutton 已添加到情节提要中。

import UIKit

class ViewController: UIViewController 

    @IBOutlet weak var textField: UITextField!
    @IBOutlet weak var button: UIButton!

    var lastY: CGFloat = 100

    override func viewDidLoad() 
        super.viewDidLoad()
    

    @IBAction func buttonClicked(_ sender: UIButton) 
        let contentView = UIView()
        addViewsTo(contentView)
        contentView.translatesAutoresizingMaskIntoConstraints = false
        view.addSubview(contentView)

        // Add size constraints to the content view (260, 30)
        NSLayoutConstraint(item: contentView, attribute: .width, relatedBy: .equal,
                           toItem: nil, attribute: .notAnAttribute, multiplier: 1.0, constant: 260.0).isActive = true
        NSLayoutConstraint(item: contentView, attribute: .height, relatedBy: .equal,
                           toItem: nil, attribute: .notAnAttribute, multiplier: 1.0, constant: 30.0).isActive = true
        // Add position constraints to the content view (horizontal center, 100 from the top)
        NSLayoutConstraint(item: contentView, attribute: .top, relatedBy: .equal, toItem: view, attribute: .top, multiplier: 1.0, constant: lastY).isActive = true
        NSLayoutConstraint(item: contentView, attribute: .centerX, relatedBy: .equal, toItem: view, attribute: .centerX, multiplier: 1.0, constant: 0.0).isActive = true

        // Update last Y position to have the gaps between views to be 10
        lastY += 40
    

    // Add label and button to the content view
    func addViewsTo(_ contentView: UIView) 
        // Add a label with size of (100, 30)
        let label = UILabel()
        label.text = textField.text
        label.frame = CGRect(x: 0.0, y: 0.0, width: 100.0, height: 30.0)
        contentView.addSubview(label)

        // Add a button with size of (150, 30)
        let button = UIButton()
        button.setTitle("Button of \(textField.text ?? "")", for: .normal)
        button.setTitleColor(.blue, for: .normal)
        button.layer.borderWidth = 1
        button.layer.borderColor = UIColor.black.cgColor
        button.frame = CGRect(x: 110.0, y: 0.0, width: 150.0, height: 30.0)
        contentView.addSubview(button)        
    

【讨论】:

谢谢!我很快就会试试看!【参考方案2】:

您的问题是关于如何以编程方式创建按钮和文本字段,然后设置约束。首先,启动 UI 元素,设置它并将其添加到您的视图控制器。然后为其分配约束。我最喜欢的约束集是 padding top、padding left、view height 和 view width。

以 UIButton 为例

let button = UIButton()
//Set up button, like title, color, etc

self.view.addSubView(button)//Add the button to the current view

//Set up constraints
let margins = view.layoutMarginsGuide
button.trailingAnchor.constraint(equalTo: margins.trailingAnchor, constant: 0).isActive = true
button.topAnchor.constraint(equalTo: margins.topAnchor, constant: 70).isActive = true
button.widthAnchor.constraint(equalToConstant: 100).isActive = true
button.heightAnchor.constraint(equalToConstant: 30).isActive = true

【讨论】:

以上是关于以编程方式创建与点击按钮关联的标签的主要内容,如果未能解决你的问题,请参考以下文章

怎样在文件夹选项中创建关联

如何以编程方式单击 WPF 中的按钮?

使用 MFC 以编程方式更改文件扩展名关联?

如何将单选按钮值与输入字段相关联

Swift - 表格视图单元格内的单击按钮不会在该单元格的功能处调用确实选择行

文件夹选项创建关联 这个怎么弄?