Как вы создаете UIImage View Programmatically - Swift
Я пытаюсь создать UIImage View программно, у меня есть новое представление, и я попытался сделать это
let imageName = "yourImage.png"
yourview.backgroundColor = UIColor.colorWithPatternImage(UIImage(named:imageName))
это не сработало, потому что я не знаю, что это должно быть myview во второй строке.
Вопрос:
Как заставить UIImageView появляться на экране путем его кодирования вместо того, чтобы делать это в раскадровке
Ответы
Ответ 1
Сначала вы создаете UIImage
из своего файла изображения, затем создайте UIImageView
из этого:
let imageName = "yourImage.png"
let image = UIImage(named: imageName)
let imageView = UIImageView(image: image!)
Наконец, вам нужно предоставить imageView
фрейм и добавить его для просмотра, чтобы он был видимым:
imageView.frame = CGRect(x: 0, y: 0, width: 100, height: 200)
view.addSubview(imageView)
Ответ 2
Сначала создайте UIImageView, затем добавьте изображение в UIImageView.
var imageView : UIImageView
imageView = UIImageView(frame:CGRectMake(10, 50, 100, 300));
imageView.image = UIImage(named:"image.jpg")
self.view.addSubview(imageView)
Ответ 3
Этот ответ обновляется до Swift 3.
Так вы можете программно добавлять представление изображения, где вы можете контролировать ограничения.
Class ViewController: UIViewController {
let someImageView: UIImageView = {
let theImageView = UIImageView()
theImageView.image = UIImage(named: "yourImage.png")
theImageView.translatesAutoresizingMaskIntoConstraints = false //You need to call this property so the image is added to your view
return theImageView
}()
override func viewDidLoad() {
super.viewDidLoad()
view.addSubview(someImageView) //This add it the view controller without constraints
someImageViewConstraints() //This function is outside the viewDidLoad function that controls the constraints
}
// do not forget the `.isActive = true` after every constraint
func someImageViewConstraints() {
someImageView.widthAnchor.constraint(equalToConstant: 180).isActive = true
someImageView.heightAnchor.constraint(equalToConstant: 180).isActive = true
someImageView.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true
someImageView.centerYAnchor.constraint(equalTo: view.centerYAnchor, constant: 28).isActive = true
}
}
Ответ 4
Вы можете использовать выше в одной строке.
let imageView = UIImageView(image: UIImage(named: "yourImage.png")!)
Ответ 5
Спасибо, MEnnabah, просто добавьте в свой код, где вам не указан знак =
в объявлении:
let someImageView: UIImageView = {
let theImageView = UIImageView()
theImageView.image = UIImage(named: "yourImage.png")
theImageView.translatesAutoresizingMaskIntoConstraints = false //You need to call this property so the image is added to your view
return theImageView
}()
Все остальное, все идеально подходит для Swift 3.
Ответ 6
В Swift 3.0:
var imageView : UIImageView
imageView = UIImageView(frame:CGRect(x:10, y:50, width:100, height:300));
imageView.image = UIImage(named:"Test.jpeg")
self.view.addSubview(imageView)
Ответ 7
Свифт 4:
Сначала создайте выход для вашего UIImageView
@IBOutlet var infoImage: UIImageView!
Затем используйте свойство изображения в UIImageView
infoImage.image = UIImage(named: "icons8-info-white")
Ответ 8
В Swift 4.2 и Xcode 10.1
//Create image view simply like this.
let imgView = UIImageView()
imgView.frame = CGRect(x: 200, y: 200, width: 200, height: 200)
imgView.image = UIImage(named: "yourimagename")//Assign image to ImageView
imgView.imgViewCorners()
view.addSubview(imgView)//Add image to our view
//Add image view properties like this(This is one of the way to add properties).
extension UIImageView {
//If you want only round corners
func imgViewCorners() {
layer.cornerRadius = 10
layer.borderWidth = 1.0
layer.masksToBounds = true
}
}