{"id":346119,"date":"2023-03-01T09:02:08","date_gmt":"2023-03-01T09:02:08","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=346119"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=346119","title":{"rendered":"<span>iOS-\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u0441\u043e SnapKit: \u0441\u043f\u0430\u0441\u0430\u0435\u043c \u043a\u043e\u043d\u0441\u043e\u043b\u044c \u043e\u0442 \u043f\u0440\u043e\u0441\u0442\u044b\u043d\u0438 \u043e\u0448\u0438\u0431\u043e\u043a \u0438 \u0443\u0441\u043a\u043e\u0440\u044f\u0435\u043c \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0443 UI<\/span>"},"content":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041f\u0440\u0438\u0432\u0435\u0442, \u044f \u0414\u0430\u0448\u0430, \u0437\u0430\u043d\u0438\u043c\u0430\u044e\u0441\u044c iOS\u2011\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u043e\u0439 \u0432\u00a0\u0421\u0440\u0430\u0432\u043d\u0438. \u041c\u044b \u0432\u00a0\u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u0435 \u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u0441\u044f SnapKit\u00a0\u2014 \u043f\u043e\u043c\u043e\u0433\u0430\u0435\u0442 \u043d\u0430\u043c \u0440\u0435\u0432\u044c\u044e\u0438\u0442\u044c \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0432\u00a0\u043e\u0431\u0449\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u0445\u00a0\u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u0438 \u043f\u0440\u043e\u0449\u0435. \u0418\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u0439, \u043d\u043e\u00a0\u044f \u0437\u0430\u043c\u0435\u0442\u0438\u043b\u0430 \u0442\u0435\u043d\u0434\u0435\u043d\u0446\u0438\u044e: \u0441\u0442\u043e\u0438\u0442 \u0432\u00a0\u0440\u0430\u0431\u043e\u0442\u0435 \u043f\u043e\u044f\u0432\u0438\u0442\u044c\u0441\u044f \u0441\u043b\u043e\u0436\u043d\u044b\u043c \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430\u043c \u0432\u0451\u0440\u0441\u0442\u043a\u0438, \u043a\u0430\u043a\u00a0\u0441\u0440\u0430\u0437\u0443 \u0432\u00a0\u0440\u0430\u0437\u044b \u0440\u0430\u0441\u0442\u0451\u0442 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c, \u0447\u0442\u043e\u00a0UI \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u043e\u043a, \u0430\u00a0\u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u0431\u0443\u0434\u0435\u0442 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0442\u044c\u0441\u044f \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u043e\u0448\u0438\u0431\u043e\u043a LayoutConstraints, \u043b\u043e\u0433\u0438 \u0437\u0430\u0441\u043e\u0440\u044f\u044e\u0442\u0441\u044f, \u043d\u0430\u0439\u0442\u0438 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u043e\u043b\u0435\u0437\u043d\u0443\u044e \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0441\u043b\u043e\u0436\u043d\u0435\u0435. <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w780q1\/getpro\/habr\/upload_files\/26e\/0ea\/4d2\/26e0ea4d28fc0dfefaed6bdbac24b2ab.jpeg\" width=\"1600\" height=\"900\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/26e\/0ea\/4d2\/26e0ea4d28fc0dfefaed6bdbac24b2ab.jpeg\" data-blurred=\"true\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0412\u00a0\u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0441\u043f\u0430\u0441\u0442\u0438 \u043b\u043e\u0433\u0438 \u043e\u0442\u00a0\u043e\u0448\u0438\u0431\u043e\u043a \u043a\u043e\u043d\u0441\u0442\u0440\u0435\u0439\u043d\u0442\u043e\u0432, \u043e\u0431\u0441\u0443\u0434\u0438\u043c \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0438 \u0443\u0434\u043e\u0431\u043d\u044b\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u044b \u0434\u043b\u044f\u00a0\u0440\u0430\u0431\u043e\u0442\u044b \u0441\u00a0\u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f\u043c\u0438, \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u043c \u043a\u0440\u0430\u0435\u0432\u044b\u0435 \u0441\u043b\u0443\u0447\u0430\u0438 \u0438 \u0432\u043c\u0435\u0441\u0442\u0435 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0447\u0443\u0442\u044c \u0433\u043b\u0443\u0431\u0436\u0435 \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c\u0441\u044f \u0432\u00a0\u0442\u043e\u043d\u043a\u043e\u0441\u0442\u044f\u0445 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u043e SnapKit.<\/p>\n<h3>\u0422\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 SnapKit<\/h3>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0441\u0432\u0435\u0440\u0438\u043c\u0441\u044f, \u0447\u0442\u043e\u00a0\u0433\u043e\u0432\u043e\u0440\u0438\u043c \u043e\u0431\u00a0\u043e\u0434\u043d\u043e\u043c \u0438 \u0442\u043e\u043c\u00a0\u0436\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0435. <a href=\"https:\/\/github.com\/SnapKit\/SnapKit\"><u>SnapKit<\/u><\/a>\u00a0\u2014 \u044d\u0442\u043e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430, \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0449\u0430\u044f \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0441\u0430\u0445\u0430\u0440 \u0438 \u043e\u0431\u0435\u0440\u0442\u043a\u0438 \u0434\u043b\u044f\u00a0\u0431\u043e\u043b\u0435\u0435 \u0443\u0434\u043e\u0431\u043d\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u00a0\u043a\u043b\u0430\u0441\u0441\u043e\u043c NSLayoutConstraint, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0449\u0438\u043c \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0432\u0437\u0430\u0438\u043c\u043d\u043e\u0435 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430.<\/p>\n<p>\u041f\u0435\u0440\u0432\u044b\u0439 \u0440\u0435\u043b\u0438\u0437 SnapKit \u0441\u043b\u0443\u0447\u0438\u043b\u0441\u044f \u0435\u0449\u0451 \u0432\u00a0\u0434\u0430\u043b\u0451\u043a\u043e\u043c 2016\u00a0\u0438 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b\u0441\u044f \u043f\u043e\u0434\u00a0Swift 2.3; \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u0440\u0435\u043b\u0438\u0437 5.6.0\u00a0\u0432\u044b\u0448\u0435\u043b \u0432\u00a0\u0430\u043f\u0440\u0435\u043b\u0435 2022\u00a0\u0438 \u0443\u043c\u0435\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441\u00a0Swift 5.6. <\/p>\n<p>\u0417\u0430\u00a0\u0432\u0440\u0435\u043c\u044f \u0441\u0432\u043e\u0435\u0433\u043e \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043e\u0432\u0430\u043d\u0438\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u043e\u0431\u0440\u0435\u043b\u0430 \u043d\u0430\u0440\u043e\u0434\u043d\u0443\u044e \u043b\u044e\u0431\u043e\u0432\u044c. \u0412\u044b \u043b\u0435\u0433\u043a\u043e \u043d\u0430\u0439\u0434\u0451\u0442\u0435 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0441\u0442\u0430\u0442\u0435\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0434\u043e\u043f\u043e\u043b\u043d\u044f\u044e\u0442 <a href=\"https:\/\/snapkit.github.io\/SnapKit\/docs\/\"><u>\u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u044c\u043d\u0443\u044e \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e<\/u><\/a> \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u043c \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043e\u043c (\u043f\u0438\u0448\u0438\u0442\u0435, \u0435\u0441\u043b\u0438 \u043d\u0443\u0436\u043d\u044b \u0431\u0443\u0434\u0443\u0442 \u043d\u0430\u0432\u043e\u0434\u043a\u0438). <\/p>\n<p>\u0412\u00a0\u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u0440\u0435\u0448\u0438\u043b\u0430 \u043f\u043e\u0439\u0442\u0438 \u043f\u043e\u0445\u043e\u0436\u0438\u043c, \u043d\u043e\u00a0\u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0434\u0440\u0443\u0433\u0438\u043c \u043f\u0443\u0442\u0451\u043c: \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0435 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0438 \u043e\u0448\u0438\u0431\u043e\u043a \u0434\u043b\u044f\u00a0\u043d\u0435\u0442\u0440\u0438\u0432\u0438\u0430\u043b\u044c\u043d\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u0432\u0451\u0440\u0441\u0442\u043a\u0438 \u0438 \u0437\u0430\u00a0\u0441\u0447\u0435\u0442 \u044d\u0442\u043e\u0433\u043e \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c\u0441\u044f, \u043f\u043e\u0447\u0435\u043c\u0443 \u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u043c\u043e\u0436\u0435\u0442 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0442\u044c\u0441\u044f \u043c\u043d\u043e\u0433\u043e \u043e\u0448\u0438\u0431\u043e\u043a, \u0445\u043e\u0442\u044f UI \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0442\u0430\u043a, \u043a\u0430\u043a\u00a0\u043e\u0436\u0438\u0434\u0430\u0435\u0442\u0441\u044f.<\/p>\n<p>\u0412\u0441\u0435\u043c \u0437\u043d\u0430\u043a\u043e\u043c\u044b \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u0438, \u043a\u043e\u0433\u0434\u0430 \u043d\u0430\u0434\u043e \u0432\u00a0\u0441\u0436\u0430\u0442\u044b\u0435 \u0441\u0440\u043e\u043a\u0438 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043a\u0430\u043a\u0443\u044e\u2011\u0442\u043e \u0444\u0438\u0447\u0443, \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u044f \u043d\u043e\u0432\u044b\u0435 \u0434\u043b\u044f\u00a0\u0442\u0435\u0431\u044f \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0438. \u0412\u0440\u0435\u043c\u0435\u043d\u0438 \u043d\u0430\u00a0\u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u0435 \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0441\u0435\u0445 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u043d\u0435\u00a0\u0432\u0441\u0435\u0433\u0434\u0430 \u0445\u0432\u0430\u0442\u0430\u0435\u0442\u00a0\u2014 \u0432\u00a0\u0442\u0430\u043a\u0438\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445 \u0435\u0441\u043b\u0438 \u0432\u00a0\u0441\u043e\u0441\u0435\u0434\u043d\u0435\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u0435 \u0443\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0430\u0441\u044c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0430\u044f \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u044f, \u0441\u043c\u043e\u0442\u0440\u0438\u043c, \u043a\u0430\u043a\u00a0\u044d\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u043b\u0438 \u043a\u043e\u043b\u043b\u0435\u0433\u0438, \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u043c.<\/p>\n<p>\u0412\u0441\u0451\u00a0\u0431\u044b \u0445\u043e\u0440\u043e\u0448\u043e, \u043d\u043e\u00a0\u0431\u044b\u0432\u0430\u0435\u0442, \u0447\u0442\u043e\u00a0\u043e\u043f\u044b\u0442 \u043a\u043e\u043b\u043b\u0435\u0433 \u043d\u0435\u00a0\u0443\u0434\u0430\u0451\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0432\u00a0\u043f\u043e\u043b\u043d\u043e\u0439 \u043c\u0435\u0440\u0435\u00a0\u2014 \u0434\u0440\u0443\u0433\u0438\u0435 \u0432\u0432\u043e\u0434\u043d\u044b\u0435, \u043d\u0430\u0448\u0430 \u0444\u0438\u0447\u0430 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0431\u043e\u043b\u044c\u0448\u0435\u0433\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0441\u00a0\u0438\u0445 \u0431\u043e\u043b\u0435\u0435 \u0441\u043b\u043e\u0436\u043d\u043e\u0439 \u0432\u0437\u0430\u0438\u043c\u043e\u0441\u0432\u044f\u0437\u044c\u044e. \u0418\u043b\u0438\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0442\u0430\u043a\u0438\u043c \u043f\u0440\u043e\u0441\u0442\u044b\u043c, \u0447\u0442\u043e\u00a0\u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0447\u0442\u043e\u00a0\u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u0437\u0434\u0435\u0441\u044c \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435\u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u00a0\u2014 \u0440\u0438\u0441\u043a\u0443\u0435\u0448\u044c \u0440\u0430\u0441\u0441\u043b\u0430\u0431\u0438\u0442\u044c\u0441\u044f \u0438 \u0443\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043a\u0440\u0430\u0435\u0432\u044b\u0435 \u0441\u043b\u0443\u0447\u0430\u0438. <\/p>\n<p>\u041f\u0440\u0438\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 SnapKit \u0443\u00a0\u043c\u0435\u043d\u044f \u0447\u0430\u0441\u0442\u043e \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u043b\u0438 \u0432\u043e\u043f\u0440\u043e\u0441\u044b, \u043a\u0430\u043a\u00a0\u044d\u0442\u043e \u0432\u0441\u0451 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u0438 \u043c\u043e\u0436\u043d\u043e\u00a0\u043b\u0438 \u0434\u043e\u0441\u0442\u0438\u0447\u044c \u0442\u0430\u043a\u043e\u0433\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438, \u0447\u0442\u043e\u0431\u044b \u0434\u0430\u0436\u0435 \u0431\u0435\u0437\u00a0\u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0441\u043a\u0430\u0437\u0430\u0442\u044c: \u0432\u043e\u0442 \u0437\u0434\u0435\u0441\u044c \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e, \u0430\u00a0\u0437\u0434\u0435\u0441\u044c \u0432\u0435\u0440\u0441\u0442\u043a\u0430 \u043f\u043e\u043f\u043b\u044b\u0432\u0451\u0442. \u0412\u0434\u043e\u0431\u0430\u0432\u043e\u043a \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044f \u0441\u00a0\u043f\u043e\u0440\u0442\u044f\u043d\u043a\u043e\u0439 \u043e\u0448\u0438\u0431\u043e\u043a LayoutConstraints \u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u043f\u0440\u0438\u043d\u043e\u0441\u0438\u0442 \u043e\u0449\u0443\u0449\u0435\u043d\u0438\u0435 \u043d\u0435\u0430\u043a\u043a\u0443\u0440\u0430\u0442\u043d\u043e\u0441\u0442\u0438. \u0412\u0441\u0451 \u044d\u0442\u043e \u043f\u043e\u0434\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u043e \u043c\u0435\u043d\u044f \u043a\u00a0\u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u044e \u043a\u0440\u0430\u0435\u0432\u044b\u0445 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u0432\u00a0\u0440\u0430\u0431\u043e\u0442\u0435 SnapKit; \u043e\u00a0\u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430\u0445 \u0445\u043e\u0447\u0443 \u0432\u0430\u043c \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u0442\u044c \u0432\u00a0\u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435.<\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u043d\u0430\u0432\u043e\u0434\u0438\u0442\u044c \u043f\u043e\u0440\u044f\u0434\u043e\u043a \u0441\u043e SnapKit. <\/p>\n<h3>\u0411\u043e\u043b\u044c\u0448\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432\u00a0\u00a0<\/h3>\n<p>\u041f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u044e \u0440\u0430\u0441\u0448\u0438\u0440\u0438\u0442\u044c \u0441\u043f\u0438\u0441\u043e\u043a \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0445 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432, \u0441\u00a0\u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0441\u043e\u0437\u0434\u0430\u044e\u0442\u0441\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f Layout. \u0421\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u044f \u0441\u043e\u0431\u0440\u0430\u043b\u0430 \u0432\u00a0\u0442\u0430\u0431\u043b\u0438\u0446\u0435 1; \u0435\u0449\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0437\u0432\u0430\u0442\u044c \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u043c\u0438\u00a0\u2014 \u0432\u00a0\u0442\u0430\u0431\u043b\u0438\u0446\u0435 2.<\/p>\n<details class=\"spoiler\">\n<summary>\u0422\u0430\u0431\u043b\u0438\u0446\u0430 1<\/summary>\n<div class=\"spoiler__content\">\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td>\n<p align=\"left\">ViewAttribute<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutAttribute<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.left<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.left<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.right<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.right<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.top<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.top<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.bottom<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.bottom<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.leading<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.leading<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.trailing<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.trailing<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.width<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.width<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.height<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.height<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.centerX<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.centerX<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.centerY<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.centerY<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.lastBaseline<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.lastBaseline<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<\/div>\n<\/details>\n<details class=\"spoiler\">\n<summary>\u0422\u0430\u0431\u043b\u0438\u0446\u0430 2<\/summary>\n<div class=\"spoiler__content\">\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td>\n<p align=\"left\">ViewAttribute<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u041e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u0435\u043c\u044b\u0435 ViewAttribute<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.edge<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.horizontalEdges, view.snp.verticalEdges<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.horizontalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.left, view.snp.right<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.verticalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.top, view.snp.bottom<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.directionalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.directionalHorizontalEdges, view.snp.directionalVerticalEdges<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.directionalHorizontalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.leading, view.snp.trailing<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.directionalVerticalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.top, view.snp.bottom<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.size<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.width, view.snp.height<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.center<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.centerX, view.snp.centerY<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.margins<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.leftMargin, view.snp.rightMargin,\u00a0 view.snp.topMargin, view.snp.bottomMargin<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.directionalMargins<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.leadingMargin, view.snp.trailingMargin, view.snp.topMargin, view.snp.bottomMargin<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.centerWithinMargins<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.centerXWithinMargins, view.snp.centerYWithinMargins<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<\/div>\n<\/details>\n<p>\u041e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b \u043d\u0443\u0436\u043d\u044b, \u0447\u0442\u043e\u0431\u044b \u0441\u043e\u043a\u0440\u0430\u0442\u0438\u0442\u044c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043a\u043e\u0434\u0430 \u043f\u0440\u0438\u00a0\u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439, \u0430\u00a0\u0442\u0430\u043a\u0436\u0435 \u0434\u043b\u044f\u00a0\u0443\u043f\u0440\u043e\u0449\u0435\u043d\u0438\u044f \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044f, \u0447\u0442\u043e\u00a0\u043c\u044b \u0445\u043e\u0442\u0435\u043b\u0438 \u0432\u0441\u0435\u043c \u044d\u0442\u0438\u043c \u0441\u043a\u0430\u0437\u0430\u0442\u044c.<\/p>\n<h3>\u0427\u0442\u043e \u043f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u043e\u043c SnapKit, \u043d\u0430 \u043f\u0440\u0438\u043c\u0435\u0440\u0435<\/h3>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0437\u0430\u0433\u043b\u044f\u043d\u0435\u043c \u0432\u0433\u043b\u0443\u0431\u044c SnapKit. \u0415\u0441\u043b\u0438 \u0445\u043e\u0442\u0438\u0442\u0435 \u0441\u0440\u0430\u0437\u0443 \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u043a\u00a0\u0440\u0430\u0437\u0431\u043e\u0440\u0443 \u043f\u0440\u0438\u0447\u0438\u043d <a href=\"#UIProblems\">\u043e\u0448\u0438\u0431\u043e\u043a \u0434\u043b\u044f\u00a0\u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/a> (\u0433\u043b\u0430\u0432\u043d\u043e\u0435, \u0440\u0430\u0434\u0438 \u0447\u0435\u0433\u043e \u043c\u044b \u0437\u0434\u0435\u0441\u044c!), \u043c\u043e\u0436\u0435\u0442\u0435 \u0441\u043c\u0435\u043b\u043e \u043f\u0440\u043e\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u044d\u0442\u0443 \u0447\u0430\u0441\u0442\u044c \u0441\u0442\u0430\u0442\u044c\u0438. \u0415\u0441\u043b\u0438\u00a0\u0436\u0435 \u0445\u043e\u0447\u0435\u0442\u0441\u044f \u043e\u0441\u0432\u0435\u0436\u0438\u0442\u044c \u0432\u00a0\u043f\u0430\u043c\u044f\u0442\u0438 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438, \u0442\u043e\u0433\u0434\u0430 \u043f\u043e\u0435\u0445\u0430\u043b\u0438.<\/p>\n<p>\u0412\u00a0SnapKit \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0442 \u0442\u0440\u0438 \u043f\u0443\u0431\u043b\u0438\u0447\u043d\u044b\u0445 \u043c\u0435\u0442\u043e\u0434\u0430, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0449\u0438\u0445 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c \u0441\u043f\u0438\u0441\u043a\u043e\u043c \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 (LayoutConstraints):<\/p>\n<ul>\n<li>\n<p><code>makeConstraints(_ closure:)<\/code>; <\/p>\n<\/li>\n<li>\n<p><code>remakeConstraints(_ closure:)<\/code>; <\/p>\n<\/li>\n<li>\n<p><code>updateConstraints(_ closure:)<\/code>. <\/p>\n<\/li>\n<\/ul>\n<p>\u0415\u0449\u0451 \u0435\u0441\u0442\u044c \u0447\u0435\u0442\u0432\u0451\u0440\u0442\u044b\u0439 \u043c\u0435\u0442\u043e\u0434\u00a0\u2014 <code>removeConstraints()<\/code>; \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043e\u0447\u0438\u0441\u0442\u0438\u0442\u044c \u0441\u043f\u0438\u0441\u043e\u043a \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u0443\u00a0\u0432\u044b\u0431\u0440\u0430\u043d\u043d\u043e\u0433\u043e \u0432\u044c\u044e.<\/p>\n<p>\u041f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u043f\u043e\u043c\u0435\u0441\u0442\u0438\u0442\u044c \u043a\u043d\u043e\u043f\u043a\u0443 <code>button<\/code> \u043f\u043e\u00a0\u0446\u0435\u043d\u0442\u0440\u0443 \u0435\u0435 <code>superView<\/code>. \u0422\u043e\u0433\u0434\u0430 \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u0437\u0430\u043f\u0438\u0441\u044c:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {   $0.center.equalToSuperview() }<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u0443\u0433\u043b\u0443\u0431\u0438\u0442\u044c\u0441\u044f \u0432\u00a0\u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e, \u0442\u043e \u0432\u00a0\u043c\u0435\u0442\u043e\u0434\u0435 <code>makeConstraints(_ closure:)<\/code> \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0432\u044b\u0437\u043e\u0432 \u043c\u0435\u0442\u043e\u0434\u0430 <code>makeConstraints(item:, closure:)<\/code> \u043a\u043b\u0430\u0441\u0441\u0430 <code>ConstraintMaker<\/code> (\u043f\u043e\u0434\u043e\u0431\u0438\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430 \u0444\u0430\u0441\u0430\u0434), \u0432\u00a0\u043a\u043e\u0442\u043e\u0440\u043e\u043c \u043c\u044b \u0443\u0432\u0438\u0434\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f:<\/p>\n<p>1. \u0418\u0437\u00a0\u043d\u0430\u0448\u0435\u0439 \u043a\u043d\u043e\u043f\u043a\u0438 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 <code>ConstraintMaker<\/code>, \u0432\u00a0\u0445\u043e\u0434\u0435 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0430\u0448\u0435\u0439 \u043a\u043d\u043e\u043f\u043a\u0438 \u0432\u044b\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f <code>translatesAutoresizingMaskIntoConstraints = false<\/code>, \u0434\u043b\u044f\u00a0\u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0434\u0430\u043b\u0435\u0435 \u0438\u043c\u0435\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0442\u044c <code>NSLayoutConstraint<\/code>.<\/p>\n<p>2. \u0414\u0430\u043b\u0435\u0435 \u043e\u0431\u0440\u0430\u0442\u043d\u043e \u0432\u00a0\u0437\u0430\u043c\u044b\u043a\u0430\u043d\u0438\u0435 \u043f\u0435\u0440\u0435\u0434\u0430\u0451\u0442\u0441\u044f ConstraintMaker, \u0433\u0434\u0435 \u043c\u044b \u0435\u0433\u043e \u043e\u0431\u043e\u0433\u0430\u0449\u0430\u0435\u043c \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u043c\u0438 <code>ConstraintMakerExtendable<\/code>: <code>center<\/code>, <code>size<\/code>, <code>edges<\/code> \u0438 \u043f\u0440\u043e\u0447\u0438\u043c.<\/p>\n<p>\u041a\u0430\u0436\u0434\u0430\u044f \u0441\u0442\u0440\u043e\u043a\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u0437\u0430\u043c\u044b\u043a\u0430\u043d\u0438\u044f \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u0432\u00a0\u0432\u044b\u0437\u043e\u0432\u0443 \u043c\u0435\u0442\u043e\u0434\u0430 <code>makeExtendableWithAttributes(_:)<\/code> (\u0432 \u043d\u0430\u0448\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440\u0435 \u0434\u043b\u044f\u00a0\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430 center), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442 \u0432\u00a0\u0441\u043f\u0438\u0441\u043e\u043a descriptions \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0430 <code>ConstraintMaker<\/code> \u043e\u0431\u044a\u0435\u043a\u0442 <code>ConstraintDescription<\/code> (\u043a\u043b\u0430\u0441\u0441 \u0441\u00a0\u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f) \u0441\u00a0\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u043c, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u043c \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u043c\u0443 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044e (\u043b\u0438\u0431\u043e \u0441\u00a0\u043d\u0430\u0431\u043e\u0440\u043e\u043c \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432, \u0435\u0441\u043b\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u043c), \u0430\u00a0\u0434\u0430\u043b\u044c\u0448\u0435 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u043e\u0431\u044a\u0435\u043a\u0442 <code>ConstraintMakerExtendable<\/code>, \u043d\u0430\u0441\u043b\u0435\u0434\u043d\u0438\u043a\u0430 <code>ConstraintMakerRelatable<\/code>. <\/p>\n<p>\u0412\u00a0\u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, center \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u043c \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u043c, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u00a0ConstraintDescription \u0431\u0443\u0434\u0435\u0442 \u043f\u0435\u0440\u0435\u0434\u0430\u043d <code>OptionSet<\/code> <code>[.centerX, .centerY]<\/code>.<\/p>\n<p>3. \u041f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a\u00a0\u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u043d \u0430\u0442\u0440\u0438\u0431\u0443\u0442 center, \u0434\u043b\u044f\u00a0\u043d\u0435\u0433\u043e \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043c\u0435\u0442\u043e\u0434 <code>equalToSuperview()<\/code>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u043a\u00a0\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0430 <code>ConstraintMakerEditable<\/code>. <\/p>\n<p><code>ConstraintMakerEditable<\/code> \u0430\u043a\u043a\u0443\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442 \u0432\u00a0\u0441\u0435\u0431\u0435 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043e\u00a0\u0442\u043e\u043c, \u0441\u00a0\u043a\u0430\u043a\u043e\u0439 \u0432\u044c\u044e \u0431\u0443\u0434\u0435\u0442 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u043e\u0432\u0430\u0442\u044c \u043d\u0430\u0448\u0430 <code>button<\/code> \u043f\u0440\u0438\u00a0\u043f\u043e\u0437\u0438\u0446\u0438\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0438 \u043a\u0430\u043a\u043e\u0439 \u0442\u0438\u043f \u0432\u0437\u0430\u0438\u043c\u043e\u0441\u0432\u044f\u0437\u0438 \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f. \u0412\u00a0\u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 center \u043d\u0430\u0448\u0435\u0439 \u043a\u043d\u043e\u043f\u043a\u0438 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0432\u0435\u043d \u0446\u0435\u043d\u0442\u0440\u0443 \u0435\u0451 <code>superView<\/code>. \u0410\u00a0\u0435\u0441\u043b\u0438 <code>superView<\/code> \u043d\u0435\u00a0\u0431\u0443\u0434\u0435\u0442 \u043d\u0430\u0439\u0434\u0435\u043d, \u0442\u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0441 <code>fatalError(\"Expected superview but found nil when attempting make constraint `equalToSuperview`.\")<\/code>. <\/p>\n<p>\u0422\u0430\u043a\u0436\u0435 \u0443 <code>ConstraintMakerEditable<\/code> \u0435\u0441\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 <code>sourceLocation<\/code>, \u0432\u00a0\u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442\u0441\u044f \u043d\u0430\u0438\u043c\u0435\u043d\u043e\u0432\u0430\u043d\u0438\u0435 \u0444\u0430\u0439\u043b\u0430 \u0438 \u043d\u043e\u043c\u0435\u0440 \u0441\u0442\u0440\u043e\u043a\u0438, \u043d\u0430\u00a0\u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043f\u0440\u043e\u0438\u0437\u043e\u0448\u0451\u043b \u0432\u044b\u0437\u043e\u0432 \u043c\u0435\u0442\u043e\u0434\u0430 <code>equalToSuperview()<\/code>, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u043f\u0440\u0438\u00a0\u0432\u044b\u0432\u043e\u0434\u0435 \u043e\u0448\u0438\u0431\u043e\u043a.<\/p>\n<p>4. \u041a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u043e\u00a0\u0432\u0441\u0435\u043c \u0441\u0442\u0440\u043e\u043a\u0430\u043c \u0432\u00a0\u0437\u0430\u043c\u044b\u043a\u0430\u043d\u0438\u0438; \u0441\u00a0\u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0446\u0438\u043a\u043b\u0430 <code>for<\/code> \u043f\u0435\u0440\u0435\u0431\u0438\u0440\u0430\u044e\u0442\u0441\u044f <code>descriptions<\/code>; \u0438\u0437\u00a0\u043d\u0438\u0445 \u0434\u043e\u0441\u0442\u0430\u044e\u0442\u0441\u044f \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b <code>constraint<\/code> \u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0432\u00a0\u043c\u0430\u0441\u0441\u0438\u0432.<\/p>\n<p>5. \u0414\u043b\u044f\u00a0\u043a\u0430\u0436\u0434\u043e\u0433\u043e <code>constraint<\/code> \u0438\u0437\u00a0\u044d\u0442\u043e\u0433\u043e \u043c\u0430\u0441\u0441\u0438\u0432\u0430 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043c\u0435\u0442\u043e\u0434 <code>activateIfNeeded<\/code> \u0441\u00a0\u0444\u043b\u0430\u0433\u043e\u043c updatingExisting \u0432\u00a0\u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 <code>false<\/code>, \u0447\u0442\u043e\u00a0\u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u043a\u00a0\u0432\u044b\u0437\u043e\u0432\u0443 \u043c\u0435\u0442\u043e\u0434\u0430 <code>NSLayoutConstraint.activate<\/code> \u0434\u043b\u044f\u00a0\u0430\u043a\u0442\u0438\u0432\u0430\u0446\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f.<\/p>\n<p>\u0424\u043b\u0430\u0433 <code>updatingExisting<\/code> \u043d\u0443\u0436\u0435\u043d, \u0447\u0442\u043e\u0431\u044b \u0440\u0430\u0437\u043b\u0438\u0447\u0430\u0442\u044c \u0434\u0432\u0430 \u043c\u0435\u0442\u043e\u0434\u0430: <code>makeConstraints<\/code> \u0438 <code>updateConstraints<\/code>. \u041f\u0435\u0440\u0432\u044b\u0439 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 \u0441\u043f\u0438\u0441\u043e\u043a \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u00ab\u0441 \u043d\u0443\u043b\u044f\u00bb, \u0432\u0442\u043e\u0440\u043e\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c \u0443\u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f. \u041f\u0440\u0438\u043c\u0435\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u043e, \u0447\u0442\u043e\u00a0\u043f\u0440\u0438\u00a0\u0432\u044b\u0437\u043e\u0432\u0435 \u0442\u0440\u0435\u0442\u044c\u0435\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 (<code>remakeConstraints<\/code>) \u0441\u043f\u0435\u0440\u0432\u0430 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f <code>removeConstraints<\/code>, \u0432\u00a0\u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0434\u043b\u044f\u00a0\u0432\u0441\u0435\u0445 constraints \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043c\u0435\u0442\u043e\u0434 <code>deactivateIfNeeded<\/code> (<code>NSLayoutConstraint.deactivate(_:)<\/code>), \u043a\u0430\u0436\u0434\u043e\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u0443\u0434\u0430\u043b\u044f\u0435\u0442\u0441\u044f \u0438\u0437\u00a0\u043c\u0430\u0441\u0441\u0438\u0432\u0430 <code>constraints<\/code>, \u0430\u00a0\u0443\u0436\u0435 \u043f\u043e\u0442\u043e\u043c \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f <code>makeConstraints<\/code>.<\/p>\n<p>\u041f\u0440\u0438\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f (<code>updateConstraints<\/code>) \u0444\u043b\u0430\u0433 <code>updatingExisting<\/code> \u0432\u00a0\u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 <code>true<\/code> \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u0441\u0431\u043e\u0440 \u0432\u0441\u0435\u0445 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 <code>layoutConstraints<\/code> \u0434\u043b\u044f\u00a0\u0432\u044c\u044e \u0432\u00a0\u043c\u0430\u0441\u0441\u0438\u0432, \u043f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u0432\u00a0\u0446\u0438\u043a\u043b\u0435 \u0438\u0434\u0451\u0442 \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u0435 \u043a\u00a0\u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0443 <code>LayoutConstraint<\/code>. \u0415\u0441\u043b\u0438 \u0442\u0430\u043a\u043e\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0432\u00a0\u043c\u0430\u0441\u0441\u0438\u0432\u0435, \u0442\u043e \u043e\u043d\u043e \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442\u0441\u044f, \u0435\u0441\u043b\u0438 \u043d\u0435\u0442\u00a0\u2014 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f <code>fatalError(\"Updated constraint could not find existing matching constraint to update: \\(layoutConstraint)\")<\/code>.<\/p>\n<p>\u0415\u0441\u0442\u044c\u00a0\u043b\u0438 \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u0432\u00a0\u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439? \u0415\u0441\u043b\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u0439 \u0430\u0442\u0440\u0438\u0431\u0443\u0442 center \u0432\u043c\u0435\u0441\u0442\u043e <code>centerX<\/code> \u0438 <code>centerY<\/code>, \u0442\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u044b\u0445 \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0432\u0441\u0435\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0434\u043b\u044f\u00a0\u043f\u043e\u0441\u0442\u0440\u043e\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u0443\u043c\u0435\u043d\u044c\u0448\u0438\u0442\u0441\u044f, \u0447\u0442\u043e\u00a0\u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u0442\u044c \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430\u00a0\u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0434\u0440\u0443\u0433\u0438\u0445 \u0437\u0430\u0434\u0430\u0447.<\/p>\n<h3>\u041e\u0448\u0438\u0431\u043a\u0438 \u043f\u0440\u0438 \u0432\u044b\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/h3>\n<p><a class=\"anchor\" name=\"UIProblems\" id=\"UIProblems\"><\/a><\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0442\u0435\u043f\u0435\u0440\u044c \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u0442\u044c\u0441\u044f, \u043e\u0442\u043a\u0443\u0434\u0430 \u043c\u043e\u0433\u0443\u0442 \u0432\u0437\u044f\u0442\u044c\u0441\u044f \u0442\u0435 \u0441\u0430\u043c\u044b\u0435 \u043e\u0448\u0438\u0431\u043a\u0438 \u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438\u00a0\u2014 \u0447\u0442\u043e\u00a0\u043c\u043e\u0436\u0435\u0442 \u043f\u043e\u0439\u0442\u0438 \u043d\u0435\u00a0\u0442\u0430\u043a \u043f\u0440\u0438\u00a0\u0432\u044b\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439. \u0422\u0443\u0442 \u0443\u00a0\u043c\u0435\u043d\u044f \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0441\u044f \u0441\u043f\u0438\u0441\u043e\u043a \u0438\u0437 6\u00a0\u043b\u043e\u0432\u0443\u0448\u0435\u043a, \u0443\u0433\u043e\u0434\u0438\u0442\u044c \u0432\u00a0\u043a\u043e\u0442\u043e\u0440\u044b\u0435, \u0443\u0432\u044b, \u043f\u0440\u043e\u0449\u0435, \u0447\u0435\u043c \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c\u00a0\u0431\u044b.<\/p>\n<h4>\u041b\u043e\u0432\u0443\u0448\u043a\u0430 1: \u043d\u0435 \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u0432\u0441\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f<\/h4>\n<p>\u041f\u043e\u00a0\u043c\u043e\u0435\u043c\u0443 \u043e\u043f\u044b\u0442\u0443 \u0441\u043f\u0438\u0441\u043e\u043a \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u0437\u0430\u0447\u0430\u0441\u0442\u0443\u044e \u0441\u0432\u043e\u0434\u0438\u0442\u0441\u044f \u043a\u00a0\u0442\u0430\u043a\u043e\u043c\u0443:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {   $0.center.equalToSuperview() }<\/code><\/pre>\n<p>\u0421\u043f\u0438\u0441\u043e\u043a \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u043d\u0435\u00a0\u043f\u043e\u043b\u043d\u044b\u0439\u00a0\u2014 \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u0430\u044f \u043a\u043d\u043e\u043f\u043a\u0430 \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0439\u0442\u0438 \u0437\u0430\u00a0\u043f\u0440\u0435\u0434\u0435\u043b\u044b \u0441\u0432\u043e\u0435\u0433\u043e <code>superView<\/code> \u0438 \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u043d\u0435\u00a0\u0441\u043a\u0430\u0436\u0435\u0442, \u0447\u0442\u043e\u00a0\u0447\u0442\u043e\u2011\u0442\u043e \u043f\u043e\u0448\u043b\u043e \u043d\u0435\u00a0\u0442\u0430\u043a (\u0438 \u0434\u0430\u0436\u0435 \u043e\u0448\u0438\u0431\u043e\u043a Layout \u043d\u0435\u00a0\u0431\u0443\u0434\u0435\u0442).<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/e48\/992\/fc7\/e48992fc76ba600c226d05d42a679492.png\" alt=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0434\u043e \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439\" title=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0434\u043e \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e48\/992\/fc7\/e48992fc76ba600c226d05d42a679492.png\"\/><figcaption>\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0434\u043e \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/figcaption><\/figure>\n<p><strong>\u0420\u0435\u0448\u0435\u043d\u0438\u0435<\/strong>: \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043f\u043e \u043e\u0434\u043d\u043e\u043c\u0443 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044e \u043f\u043e \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u0438 \u0438 \u043f\u043e \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u0438:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {   $0.center.equalToSuperview()   $0.top.left.greaterThanOrEqualToSuperview() }<\/code><\/pre>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/b17\/1b6\/567\/b171b6567c2fabeb6fb64aa1b2c7b80a.png\" alt=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u043f\u043e\u0441\u043b\u0435 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439\" title=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u043f\u043e\u0441\u043b\u0435 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b17\/1b6\/567\/b171b6567c2fabeb6fb64aa1b2c7b80a.png\"\/><figcaption>\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u043f\u043e\u0441\u043b\u0435 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/figcaption><\/figure>\n<p>\u0412\u00a0\u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043d\u0430\u043c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u043f\u043e\u00a0\u043e\u0434\u043d\u043e\u043c\u0443 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044e \u0434\u043b\u044f\u00a0\u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0437\u00a0\u043e\u0441\u0435\u0439, \u0442\u0430\u043a \u043a\u0430\u043a\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0446\u0435\u043d\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e <code>superView<\/code>.<\/p>\n<h4>\u041b\u043e\u0432\u0443\u0448\u043a\u0430 2: \u043d\u0435 \u0440\u0430\u0437\u043b\u0438\u0447\u0430\u0442\u044c offset \u0438 inset<\/h4>\n<p>\u041a\u043e\u0433\u0434\u0430 \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c <code>.offset(50)<\/code>, \u043f\u043e\u0434\u00a0\u043a\u0430\u043f\u043e\u0442\u043e\u043c \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u0430 \u043e\u0441\u0442\u0430\u0435\u0442\u0441\u044f \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u043e\u0439\u00a0\u2014 \u044d\u0442\u043e \u044d\u043a\u0432\u0438\u0432\u0430\u043b\u0435\u043d\u0442\u043d\u043e \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u044e \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430 constant \u0440\u0430\u0432\u043d\u043e\u0433\u043e 50\u00a0\u0434\u043b\u044f <code>NSLayoutConstraint<\/code>. <\/p>\n<p>\u041e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u0431\u0443\u0434\u0435\u0442 \u0442\u0430\u043a\u0438\u043c:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {   0.right.equalToSuperview().offset(50) }<\/code><\/pre>\n<p>\u042d\u0442\u043e \u043f\u0440\u0438\u0432\u0435\u0434\u0451\u0442 \u043a\u00a0\u0442\u043e\u043c\u0443, \u0447\u0442\u043e\u00a0\u043f\u0440\u0430\u0432\u0430\u044f \u0433\u0440\u0430\u043d\u0438\u0446\u0430 \u043d\u0430\u0448\u0435\u0433\u043e \u0432\u044c\u044e \u0431\u0443\u0434\u0435\u0442 \u043d\u0430 50\u00a0\u0442\u043e\u0447\u0435\u043a \u043f\u0440\u0430\u0432\u0435\u0435 \u0433\u0440\u0430\u043d\u0438\u0446\u044b \u0441\u0432\u043e\u0435\u0439 \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u0441\u043a\u043e\u0439 \u0432\u044c\u044e. \u041f\u043e\u043a\u0430 \u043f\u0440\u0438\u0440\u0430\u0432\u043d\u044f\u0435\u043c \u043b\u0435\u0432\u044b\u0439 \u043a\u0440\u0430\u0439 \u043a\u00a0\u043a\u0440\u0430\u044e <code>superView<\/code>.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/5bc\/154\/877\/5bc154877feea652a3a4ad83f6660ae6.png\" alt=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0434\u043e \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439\" title=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0434\u043e \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5bc\/154\/877\/5bc154877feea652a3a4ad83f6660ae6.png\"\/><figcaption>\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0434\u043e \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/figcaption><\/figure>\n<p>\u041a\u043e\u0433\u0434\u0430 \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c <code>.inset(50)<\/code>, \u043f\u043e\u0434\u00a0\u043a\u0430\u043f\u043e\u0442\u043e\u043c \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442\u0430 \u0437\u0430\u043c\u0435\u043d\u044f\u0435\u0442\u0441\u044f \u043d\u0430 <code>ConstraintInsets(top: CGFloat(amount), left: CGFloat(amount), bottom: CGFloat(amount), right: CGFloat(amount))<\/code>, \u0433\u0434\u0435 \u0434\u0430\u043b\u0435\u0435 <code>amount<\/code>\u00a0\u2014 \u043d\u0430\u0448 \u043e\u0442\u0441\u0442\u0443\u043f \u0432 50\u00a0\u0442\u043e\u0447\u0435\u043a. \u041f\u0440\u0438\u00a0\u043f\u0435\u0440\u0435\u0441\u0447\u0451\u0442\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u0434\u043b\u044f <code>NSLayoutConstraint<\/code> \u043e\u0442\u0441\u0442\u0443\u043f \u0432 50\u00a0\u0442\u043e\u0447\u0435\u043a \u0434\u043b\u044f\u00a0\u0443\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u0433\u043e \u043d\u0430\u043c\u0438 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430 right \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u043e\u0442\u0441\u0442\u0443\u043f\u043e\u043c \u0432 -50\u00a0\u0442\u043e\u0447\u0435\u043a (\u0435\u0441\u043b\u0438\u00a0\u0431\u044b\u043b\u043e\u00a0\u0431\u044b <code>left.inset(50)<\/code>, \u0442\u043e \u043e\u0442\u0441\u0442\u0443\u043f \u0442\u0430\u043a \u0438 \u043e\u0441\u0442\u0430\u043b\u0441\u044f\u00a0\u0431\u044b 50\u00a0\u0442\u043e\u0447\u0435\u043a). \u0418 \u0442\u0435\u043f\u0435\u0440\u044c \u043c\u044b \u0438\u043c\u0435\u0435\u043c \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043e\u0442\u0441\u0442\u0443\u043f\u0430 \u043e\u0442\u00a0\u043f\u0440\u0430\u0432\u043e\u0439 \u0433\u0440\u0430\u043d\u0438\u0446\u044b \u043d\u0430\u0448\u0435\u0433\u043e \u0432\u044c\u044e \u0434\u043e\u00a0\u043f\u0440\u0430\u0432\u043e\u0439 \u0433\u0440\u0430\u043d\u0438\u0446\u044b <code>superView<\/code>.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/5ca\/081\/ffb\/5ca081ffbadd671aec3f79dc34bf2563.png\" alt=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u043f\u043e\u0441\u043b\u0435 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439\" title=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u043f\u043e\u0441\u043b\u0435 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5ca\/081\/ffb\/5ca081ffbadd671aec3f79dc34bf2563.png\"\/><figcaption>\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u043f\u043e\u0441\u043b\u0435 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/figcaption><\/figure>\n<p>\u041e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f:\u00a0<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {   $0.edges.equalToSuperview().inset(50) }<\/code><\/pre>\n<p>\u0410\u0442\u0440\u0438\u0431\u0443\u0442 <code>edges<\/code> \u2013 \u044d\u0442\u043e \u043e\u0434\u0438\u043d \u0438\u0437 \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u0445 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0438\u0437 <code>[.horizontalEdges, .verticalEdges]<\/code>. \u0414\u043b\u044f \u043d\u0430\u0448\u0435\u0433\u043e \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u0442\u0430\u043a \u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u0441\u0442\u0441\u044f <code>ConstraintInsets(top: CGFloat(amount), left: CGFloat(amount), bottom: CGFloat(amount), right: CGFloat(amount))<\/code>, \u0433\u0434\u0435 amount \u2013 \u043d\u0430\u0448 \u043e\u0442\u0441\u0442\u0443\u043f 50, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u0430\u043b\u0435\u0435 \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u0443\u0435\u0442\u0441\u044f \u0432 \u043c\u0430\u0441\u0441\u0438\u0432 \u0438\u0437 \u0447\u0435\u0442\u044b\u0440\u0435\u0445 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 (<code>top<\/code>, <code>bottom<\/code>, <code>left<\/code>, <code>right<\/code>), \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0447\u0435\u0440\u0435\u0437 <code>NSLayoutConstraint.activate<\/code>.<\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0437\u0430\u043f\u0438\u0448\u0435\u043c \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u0438\u043d\u0430\u0447\u0435:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {   $0.edges.equalToSuperview().offset(50) }<\/code><\/pre>\n<p>\u0422\u0443\u0442 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044f \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u0430 \u0441 \u0437\u0430\u043f\u0438\u0441\u044c\u044e <code>$0.right.equalToSuperview().offset(50)<\/code>: \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 <code>offset<\/code> \u043f\u0435\u0440\u0435\u0434\u0430\u0451\u0442\u0441\u044f \u0431\u0435\u0437 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439.<\/p>\n<p>\u0411\u044b\u043b\u043e:<\/p>\n<pre><code class=\"swift\">\u25bf Optional&lt;Array&lt;NSLayoutConstraint>> \u00a0\u00a0\u25bf some : 4 elements \u00a0\u00a0\u00a0\u00a0\u25bf 0 : &lt;SnapKit.LayoutConstraint:0x600001750000@ViewController.swift#111  UIButton:0x12a3050e0.left == UIView:0x128d0d7f0.left + 50.0>  \u00a0\u00a0\u00a0\u00a0\u25bf 1 : &lt;SnapKit.LayoutConstraint:0x6000017500c0@ViewController.swift#111  UIButton:0x12a3050e0.top == UIView:0x128d0d7f0.top + 50.0>  \u00a0\u00a0\u00a0\u00a0\u25bf 2 : &lt;SnapKit.LayoutConstraint:0x600001750120@ViewController.swift#111  UIButton:0x12a3050e0.right == UIView:0x128d0d7f0.right - 50.0>  \u00a0\u00a0\u00a0\u00a0\u25bf 3 : &lt;SnapKit.LayoutConstraint:0x600001750060@ViewController.swift#111  UIButton:0x12a3050e0.bottom == UIView:0x128d0d7f0.bottom - 50.0><\/code><\/pre>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/e51\/777\/daa\/e51777daa43b7a18765749b7b27a43a0.png\" alt=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u043c inset\" title=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u043c inset\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e51\/777\/daa\/e51777daa43b7a18765749b7b27a43a0.png\"\/><figcaption>\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u043c inset<\/figcaption><\/figure>\n<p>\u0421\u0442\u0430\u043b\u043e:<\/p>\n<pre><code class=\"swift\">\u25bf Optional&lt;Array&lt;NSLayoutConstraint>>   \u25bf some : 4 elements     \u25bf 0 : &lt;SnapKit.LayoutConstraint:0x6000023e8000@ViewController.swift#111  UIButton:0x13d604fe0.left == UIView:0x13d00b720.left + 50.0>      \u25bf 1 : &lt;SnapKit.LayoutConstraint:0x6000023e80c0@ViewController.swift#111  UIButton:0x13d604fe0.top == UIView:0x13d00b720.top + 50.0>      \u25bf 2 : &lt;SnapKit.LayoutConstraint:0x6000023e8120@ViewController.swift#111  UIButton:0x13d604fe0.right == UIView:0x13d00b720.right + 50.0>      \u25bf 3 : &lt;SnapKit.LayoutConstraint:0x6000023e8060@ViewController.swift#111  UIButton:0x13d604fe0.bottom == UIView:0x13d00b720.bottom + 50.0><\/code><\/pre>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/3db\/d81\/42a\/3dbd8142a30a2dfe97b9054ef88b8576.png\" alt=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u043c offset\" title=\"\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u043c offset\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/3db\/d81\/42a\/3dbd8142a30a2dfe97b9054ef88b8576.png\"\/><figcaption>\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0441 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u043c offset<\/figcaption><\/figure>\n<p>\u0412\u0441\u0435 \u043e\u0442\u0441\u0442\u0443\u043f\u044b \u0431\u0443\u0434\u0443\u0442 \u0432 50\u00a0\u0442\u043e\u0447\u0435\u043a, \u0447\u0442\u043e\u00a0\u0437\u0430\u0441\u0442\u0430\u0432\u0438\u0442 \u0433\u0440\u0430\u043d\u0438\u0446\u044b \u043d\u0430\u0448\u0435\u0439 \u043a\u043d\u043e\u043f\u043a\u0438 \u0443\u0439\u0442\u0438 \u043f\u0440\u0430\u0432\u0435\u0435 \u0438 \u043d\u0438\u0436\u0435 \u0433\u0440\u0430\u043d\u0438\u0446 \u0435\u0451 \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u0441\u043a\u043e\u0439 \u0432\u044c\u044e; \u043f\u0440\u0438\u00a0\u044d\u0442\u043e\u043c \u043e\u0442\u0441\u0442\u0443\u043f\u044b \u0441\u043b\u0435\u0432\u0430 \u0438 \u0441\u0432\u0435\u0440\u0445\u0443 \u0431\u0443\u0434\u0443\u0442 \u0432\u043f\u043e\u043b\u043d\u0435 \u0445\u043e\u0440\u043e\u0448\u043e \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c. <\/p>\n<h4>\u041b\u043e\u0432\u0443\u0448\u043a\u0430 3: \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0442\u044c \u043b\u0438\u0448\u043d\u0438\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f<\/h4>\n<p>\u041a\u043e\u0433\u0434\u0430 \u0445\u043e\u0447\u0435\u0448\u044c, \u0447\u0442\u043e\u0431\u044b \u0442\u0432\u043e\u0439 UI \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u043b \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u0445\u043e\u0440\u043e\u0448\u043e, \u0438\u043d\u043e\u0433\u0434\u0430 \u0441\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u0441\u0442\u0440\u0430\u0445\u043e\u0432\u0430\u0442\u044c\u0441\u044f. <\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0432\u044b\u0441\u0442\u0430\u0432\u0438\u043c \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u0434\u043b\u044f\u00a0\u043d\u0430\u0448\u0435\u0439 \u043a\u043d\u043e\u043f\u043a\u0438:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {     $0.center.equalToSuperview()     $0.top.left.right.bottom.equalToSuperview().inset(50) }<\/code><\/pre>\n<p>\u041d\u0430 \u044d\u043a\u0440\u0430\u043d\u0435 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0445\u043e\u0440\u043e\u0448\u043e, \u043f\u0440\u0438 \u044d\u0442\u043e\u043c \u043e\u0431\u0449\u0435\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e <code>NSLayoutConstraint<\/code>, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e\u0442\u043e\u043c \u0431\u0443\u0434\u0435\u0442 \u0430\u043a\u0442\u0438\u0432\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0441\u0438\u0441\u0442\u0435\u043c\u0430, \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0432\u043d\u043e \u0448\u0435\u0441\u0442\u0438: \u043f\u0435\u0440\u0432\u044b\u0435 \u0434\u0432\u0430 \u0434\u043b\u044f <code>centerY<\/code> \u0438 <code>centerX<\/code> + \u043f\u043e \u043e\u0434\u043d\u043e\u043c\u0443 \u043d\u0430 \u043a\u0430\u0436\u0434\u0443\u044e \u0438\u0437 \u0441\u0442\u043e\u0440\u043e\u043d.<\/p>\n<p>\u0415\u0441\u043b\u0438 \u0436\u0435 \u043c\u044b \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u043c\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u044b\u043c\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f\u043c\u0438, \u0442\u043e \u0437\u0430\u043f\u0438\u0441\u044c \u043c\u043e\u0436\u043d\u043e \u0441\u043e\u043a\u0440\u0430\u0442\u0438\u0442\u044c \u0434\u043e \u0434\u0432\u0443\u0445 \u0441\u0442\u0440\u043e\u043a:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {     $0.center.equalToSuperview()     $0.top.left.equalToSuperview().inset(50) }<\/code><\/pre>\n<p>\u041a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e <code>NSLayoutConstraint<\/code> \u0434\u043b\u044f\u00a0\u0430\u043a\u0442\u0438\u0432\u0430\u0446\u0438\u0438 \u0441\u043e\u043a\u0440\u0430\u0442\u0438\u0442\u0441\u044f \u0434\u043e\u00a0\u0447\u0435\u0442\u044b\u0440\u0435\u0445: \u043f\u0435\u0440\u0432\u044b\u0435 \u0434\u0432\u0430 \u0434\u043b\u044f <code>centerY<\/code> \u0438 <code>centerX<\/code> + \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u043f\u043e\u00a0\u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u0438 + \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u043f\u043e\u00a0\u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u0438.<\/p>\n<p>\u0415\u0449\u0451 \u043e\u0434\u0438\u043d \u043f\u0440\u0438\u043c\u0435\u0440 \u043f\u0440\u043e\u00a0\u043f\u0435\u0440\u0435\u0441\u0442\u0440\u0430\u0445\u043e\u0432\u043a\u0443\u00a0\u2014 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u0434\u043b\u044f\u00a0\u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0445 \u0432\u044c\u044e \u0432\u043d\u0443\u0442\u0440\u0438 <code>UIStackView<\/code>. \u0421\u0442\u0435\u043a \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0443\u0434\u043e\u0431\u043d\u044b\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0434\u043b\u044f\u00a0\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0430\u0434\u0430\u043f\u0442\u0438\u0432\u043d\u043e\u0433\u043e UI, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043c\u0438\u043d\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043a\u043e\u0434\u0430 \u0434\u043b\u044f\u00a0\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u0438\u044f \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u043d\u0430\u00a0\u044d\u043a\u0440\u0430\u043d\u0435. \u041e\u043d \u0443\u043c\u0435\u0435\u0442 \u0441\u0430\u043c \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0442\u044c \u0434\u043e\u0447\u0435\u0440\u043d\u0438\u0435 \u0432\u044c\u044e \u0432\u043d\u0443\u0442\u0440\u0438 \u0441\u0435\u0431\u044f. \u041f\u0440\u0438\u00a0\u044d\u0442\u043e\u043c \u0443 <code>UIStackView<\/code> \u0435\u0441\u0442\u044c \u0440\u044f\u0434 \u043d\u0430\u0441\u0442\u0440\u043e\u0435\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e\u043c\u043e\u0433\u0443\u0442 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u0438\u0442\u044c \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b.<\/p>\n<p>\u0414\u043e\u0431\u0430\u0432\u0438\u043c \u0432\u0435\u0440\u0445\u043d\u0435\u043c\u0443 \u0434\u043e\u0447\u0435\u0440\u043d\u0435\u043c\u0443 \u0432\u044c\u044e \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0441\u0442\u0435\u043a\u0430 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f:<\/p>\n<pre><code class=\"swift\">buttonInStack.snp.makeConstraints {     $0.top.left.right.equalToSuperview() }<\/code><\/pre>\n<p>\u041d\u0438\u043a\u0430\u043a\u0438\u0445 \u0441\u0442\u0440\u0430\u043d\u043d\u043e\u0441\u0442\u0435\u0439 \u043c\u044b \u043d\u0435\u00a0\u0437\u0430\u043c\u0435\u0442\u0438\u043c. \u0414\u0430, \u044d\u0442\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u0438\u0437\u043b\u0438\u0448\u043d\u0438, \u043d\u043e\u00a0\u043d\u0438 \u043e\u0448\u0438\u0431\u043e\u043a <code>LayoutConstraints<\/code>, \u043d\u0438 \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0439 \u0432\u0451\u0440\u0441\u0442\u043a\u0438 \u044d\u0442\u043e \u043d\u0435\u00a0\u0432\u044b\u0437\u043e\u0432\u0435\u0442. <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/4dd\/d86\/564\/4ddd86564d55994f10871dc574266860.png\" alt=\"\u0412\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0441 \u043a\u043d\u043e\u043f\u043a\u0430\u043c\u0438\" title=\"\u0412\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0441 \u043a\u043d\u043e\u043f\u043a\u0430\u043c\u0438\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/4dd\/d86\/564\/4ddd86564d55994f10871dc574266860.png\"\/><figcaption>\u0412\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0441 \u043a\u043d\u043e\u043f\u043a\u0430\u043c\u0438<\/figcaption><\/figure>\n<p>\u041d\u043e\u00a0\u043f\u043e\u0434\u043e\u0436\u0434\u0438\u0442\u0435, \u0432\u043e\u0442 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440 \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u0435\u0442 \u0432\u0430\u043c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0435\u0449\u0451 \u0431\u043e\u043b\u0435\u0435 \u0430\u0434\u0430\u043f\u0442\u0438\u0432\u043d\u044b\u0439 \u0434\u0438\u0437\u0430\u0439\u043d, \u0432\u00a0\u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0435\u0441\u043b\u0438 \u044d\u043a\u0440\u0430\u043d \u0431\u043e\u043b\u044c\u0448\u043e\u0439, \u0442\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b \u0432\u00a0\u043d\u0430\u0448\u0435\u043c \u0441\u0442\u0435\u043a\u0435 \u0431\u0443\u0434\u0443\u0442 \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u044f\u0442\u044c\u0441\u044f \u043f\u043e\u00a0\u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u0438; \u0430\u00a0\u0435\u0441\u043b\u0438 \u044d\u043a\u0440\u0430\u043d \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u0438\u0439, \u0442\u043e \u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u0443\u044e \u0432\u0451\u0440\u0441\u0442\u043a\u0443. \u0415\u0441\u043b\u0438 \u043d\u0435\u00a0\u043f\u043e\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u0434\u043b\u044f\u00a0\u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0434\u043e\u0447\u0435\u0440\u043d\u0435\u0433\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430, \u0442\u043e \u043c\u044b \u0443\u0432\u0438\u0434\u0438\u043c \u043d\u0435\u00a0\u0442\u043e\u043b\u044c\u043a\u043e \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u043e\u0448\u0438\u0431\u043e\u043a, \u043d\u043e\u00a0\u0438 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043d\u0435\u043b\u043e\u0433\u0438\u0447\u043d\u043e\u0435 \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/be8\/42d\/540\/be842d5403008f570dc677f5b525c6cb.png\" alt=\"\u0413\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0441 \u043a\u043d\u043e\u043f\u043a\u0430\u043c\u0438 \u0438 \u043e\u0448\u0438\u0431\u043a\u0438 \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u0438\" title=\"\u0413\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0441 \u043a\u043d\u043e\u043f\u043a\u0430\u043c\u0438 \u0438 \u043e\u0448\u0438\u0431\u043a\u0438 \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u0438\" width=\"3500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/be8\/42d\/540\/be842d5403008f570dc677f5b525c6cb.png\"\/><figcaption>\u0413\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u043a \u0441 \u043a\u043d\u043e\u043f\u043a\u0430\u043c\u0438 \u0438 \u043e\u0448\u0438\u0431\u043a\u0438 \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u0438<\/figcaption><\/figure>\n<p>\u0415\u0441\u0442\u044c \u0442\u0430\u043a\u0430\u044f \u043f\u043e\u0433\u043e\u0432\u043e\u0440\u043a\u0430: \u043b\u0443\u0447\u0448\u0438\u0439 \u043a\u043e\u0434\u00a0\u2014 \u043d\u0435\u043d\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0439. \u0415\u0441\u043b\u0438 \u043f\u043e\u0441\u0442\u0443\u043f\u0438\u0442\u044c \u0432\u00a0\u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0438 \u0441\u00a0\u044d\u0442\u0438\u043c \u043f\u0440\u0430\u0432\u0438\u043b\u043e\u043c \u0432\u00a0\u043d\u0430\u0448\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440\u0435, \u0442\u043e \u043d\u0438\u0447\u0435\u0433\u043e \u043f\u0435\u0440\u0435\u0434\u0435\u043b\u044b\u0432\u0430\u0442\u044c \u043d\u0435\u00a0\u043f\u0440\u0438\u0448\u043b\u043e\u0441\u044c\u00a0\u0431\u044b.<\/p>\n<p>\u041e\u0434\u043d\u0430\u043a\u043e\u00a0\u0431\u044b\u0432\u0430\u044e\u0442 \u0441\u043b\u0443\u0447\u0430\u0438, \u043a\u043e\u0433\u0434\u0430 \u0431\u0435\u0437\u00a0\u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439, \u0434\u0430\u0436\u0435 \u0432\u043d\u0443\u0442\u0440\u0438 <code>UIStackView<\/code>\u00a0\u2014 \u043d\u0435\u00a0\u043e\u0431\u043e\u0439\u0442\u0438\u0441\u044c. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043d\u0443\u0436\u043d\u043e \u0447\u0442\u043e\u0431\u044b\u00a0\u0431\u044b\u043b\u0430 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430 \u0441\u043f\u0440\u0430\u0432\u0430 \u0438 \u0442\u0435\u043a\u0441\u0442 \u0441\u043b\u0435\u0432\u0430. \u0422\u0435\u043a\u0441\u0442 \u043c\u043e\u0436\u0435\u0442\u00a0\u0431\u044b\u0442\u044c \u043a\u0430\u043a\u043e\u0439 \u0443\u0433\u043e\u0434\u043d\u043e \u0434\u043b\u0438\u043d\u044b, \u043d\u043e\u00a0\u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0430 \u0434\u043e\u043b\u0436\u043d\u0430\u00a0\u0431\u044b\u0442\u044c \u0441\u0442\u0440\u043e\u0433\u043e 50\u00d750\u00a0\u0442\u043e\u0447\u0435\u043a. <\/p>\n<p>\u0412\u00a0\u0442\u0430\u043a\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0432\u0430\u0436\u043d\u043e \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0441\u0430\u043c \u0441\u0442\u0435\u043a, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0432 alignment \u043e\u0442\u043b\u0438\u0447\u043d\u044b\u0439 \u043e\u0442 <code>fill<\/code>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u0434\u0430\u0435\u0442\u0441\u044f \u043f\u043e\u00a0\u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e.<\/p>\n<h4>\u041b\u043e\u0432\u0443\u0448\u043a\u0430 4: \u043f\u0443\u0442\u0430\u0442\u044c left \u0438 leading, right \u0438 trailing<\/h4>\n<p>\u0417\u0430\u0447\u0430\u0441\u0442\u0443\u044e \u043d\u0430\u0434 \u0440\u0430\u0437\u043d\u0438\u0446\u0435\u0439 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043c\u043e\u0436\u043d\u043e \u043d\u0435\u00a0\u0437\u0430\u0434\u0443\u043c\u044b\u0432\u0430\u0442\u044c\u0441\u044f, \u0432\u0435\u0434\u044c \u0434\u043b\u044f\u00a0\u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0430 \u0441\u0442\u0440\u0430\u043d left \u0438 leading \u0431\u0443\u0434\u0443\u0442 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u043b\u0435\u0432\u044b\u0439 \u043a\u0440\u0430\u0439 \u0432\u044c\u044e, \u0430\u00a0right \u0438 trailing\u00a0\u2014 \u043f\u0440\u0430\u0432\u044b\u0439. <\/p>\n<p>\u041d\u043e\u00a0\u0434\u043b\u044f \u0440\u044f\u0434\u0430 \u0441\u0442\u0440\u0430\u043d, \u0433\u0434\u0435 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 UIUserInterfaceLayoutDirection (\u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u043e\u0433\u043e \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430) \u0434\u043e\u043b\u0436\u0435\u043d\u00a0\u0431\u044b\u0442\u044c rightToLeft, \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u0435 \u0431\u0443\u0434\u0435\u0442 \u0438\u043d\u043e\u0435: leading \u0431\u0443\u0434\u0435\u0442 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u043f\u0440\u0430\u0432\u044b\u0439 \u043a\u0440\u0430\u0439, trailing\u00a0\u2014 \u043b\u0435\u0432\u044b\u0439. <\/p>\n<p>\u0411\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0437\u0430\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u043c \u0432\u00a0SnapKit \u043f\u0440\u0435\u043e\u0431\u0440\u0430\u0437\u043e\u0432\u0430\u043d\u0438\u044f\u043c, \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u043d\u0435\u00a0\u0431\u0443\u0434\u0435\u0442 \u0432\u0438\u0434\u043d\u0430, \u043e\u0434\u043d\u0430\u043a\u043e, \u043f\u043e\u043b\u0435\u0437\u043d\u0430\u044f \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0430: \u043f\u043e\u043c\u043d\u0438\u0442\u044c \u043e\u0431\u00a0\u044d\u0442\u043e\u043c \u043f\u0440\u0438\u00a0\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0438 \u0432\u0435\u0437\u0434\u0435 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0442\u044c \u0435\u0434\u0438\u043d\u0443\u044e \u043b\u043e\u0433\u0438\u043a\u0443 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439.<\/p>\n<h4>\u041b\u043e\u0432\u0443\u0448\u043a\u0430 5: \u043d\u0435 \u043f\u0440\u043e\u0434\u0443\u043c\u044b\u0432\u0430\u0442\u044c \u0432\u0437\u0430\u0438\u043c\u043e\u0441\u0432\u044f\u0437\u044c \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/h4>\n<p>\u041f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u043d\u0430\u043c \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0431\u0443\u0434\u0443\u0442 \u0440\u0430\u0437\u043c\u0435\u0449\u0435\u043d\u044b \u0442\u0440\u0438 <code>UILabel<\/code> \u0441\u00a0\u0442\u0435\u043a\u0441\u0442\u043e\u043c. \u041e\u0442\u0441\u0442\u0443\u043f\u044b \u043c\u0435\u0436\u0434\u0443 \u043d\u0438\u043c\u0438 \u0440\u0430\u0437\u043d\u044b\u0435, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u044b \u0440\u0435\u0448\u0438\u043b\u0438 \u043d\u0435\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0442\u0435\u043a, \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u043b\u0438 \u043d\u0430\u00a0\u0434\u0438\u0437\u0430\u0439\u043d \u0438 \u0441\u0434\u0435\u043b\u0430\u043b\u0438 \u0432\u044b\u0432\u043e\u0434, \u0447\u0442\u043e\u00a0\u043f\u0435\u0440\u0432\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u0434\u043e\u043b\u0436\u0435\u043d\u00a0\u0431\u044b\u0442\u044c \u043f\u0440\u0438\u0436\u0430\u0442 \u043a\u00a0\u0432\u0435\u0440\u0445\u0443 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430, \u0432\u0442\u043e\u0440\u043e\u0439 \u0434\u043e\u043b\u0436\u0435\u043d \u0438\u043c\u0435\u0442\u044c \u043e\u0442\u0441\u0442\u0443\u043f 50\u00a0\u0442\u043e\u0447\u0435\u043a \u043e\u0442\u00a0\u0432\u0435\u0440\u0445\u0430, \u0430\u00a0\u0442\u0440\u0435\u0442\u0438\u0439 \u043c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u0436\u0430\u0442\u044c \u043a\u00a0\u043d\u0438\u0437\u0443 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430, \u0443\u043a\u0430\u0437\u0430\u0432 \u0434\u043b\u044f\u00a0\u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430 \u043e\u0442\u0441\u0442\u0443\u043f\u044b \u0441\u0432\u0435\u0440\u0445\u0443 \u0438 \u0441\u043d\u0438\u0437\u0443 \u044d\u043a\u0440\u0430\u043d\u0430 \u043a\u0430\u043a\u00a0\u043d\u0430\u00a0\u043c\u0430\u043a\u0435\u0442\u0435.<\/p>\n<p>\u041d\u0430\u0431\u043e\u0440 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0442\u0430\u043a:<\/p>\n<pre><code class=\"swift\">label1.snp.makeConstraints {     $0.top.left.right.equalToSuperview() }  label2.snp.makeConstraints {     $0.top.equalToSuperview().offset(50)     $0.left.right.equalToSuperview() }  label3.snp.makeConstraints {     $0.left.right.bottom.equalToSuperview() }<\/code><\/pre>\n<p>\u041f\u0440\u0438\u00a0\u0437\u0430\u043f\u0443\u0441\u043a\u0435 \u0432\u0441\u0451 \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0445\u043e\u0440\u043e\u0448\u043e, \u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u043d\u0435\u00a0\u0431\u0443\u0434\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043e\u0448\u0438\u0431\u043e\u043a.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/fc9\/4b7\/62b\/fc94b762be82f9ab7814a2f9b0620b68.png\" alt=\"\u041d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043b\u0435\u0439\u0431\u043b\u043e\u0432, \u043d\u043e \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0442\u043a\u0430\" title=\"\u041d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043b\u0435\u0439\u0431\u043b\u043e\u0432, \u043d\u043e \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0442\u043a\u0430\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/fc9\/4b7\/62b\/fc94b762be82f9ab7814a2f9b0620b68.png\"\/><figcaption>\u041d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043b\u0435\u0439\u0431\u043b\u043e\u0432, \u043d\u043e \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0442\u043a\u0430<\/figcaption><\/figure>\n<p>\u041d\u043e\u00a0\u043a \u0447\u0435\u043c\u0443 \u043c\u043e\u0436\u0435\u0442 \u043f\u0440\u0438\u0432\u0435\u0441\u0442\u0438 \u0442\u0430\u043a\u0430\u044f \u0432\u0451\u0440\u0441\u0442\u043a\u0430? \u0415\u0441\u043b\u0438 <code>label1<\/code> \u0431\u0443\u0434\u0435\u0442 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0434\u043b\u0438\u043d\u043d\u044b\u0439, \u0442\u043e \u043e\u043d \u043c\u043e\u0436\u0435\u0442 \u0437\u0430\u043d\u044f\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0435 50\u00a0\u0442\u043e\u0447\u0435\u043a \u043d\u0430\u00a0\u044d\u043a\u0440\u0430\u043d\u0435, \u0438 \u0442\u043e\u0433\u0434\u0430 \u043e\u043d \u043f\u0435\u0440\u0435\u043a\u0440\u043e\u0435\u0442 <code>label2<\/code>. \u0422\u0430\u043a\u0430\u044f\u00a0\u0436\u0435 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044f \u0438 \u0441 <code>label2<\/code> \u043f\u043e\u00a0\u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u044e \u043a <code>label3<\/code>. \u041f\u0440\u0438\u00a0\u044d\u0442\u043e\u043c \u0432\u0441\u0451 \u0435\u0449\u0451 \u043d\u0435\u00a0\u0431\u0443\u0434\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043e\u0448\u0438\u0431\u043e\u043a <code>LayoutConstraints<\/code>.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/b55\/88c\/e64\/b5588ce64b92cb702293ed7f5c328d90.png\" alt=\"\u041d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0438 \u043d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0442\u043a\u0430\" title=\"\u041d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0438 \u043d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0442\u043a\u0430\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b55\/88c\/e64\/b5588ce64b92cb702293ed7f5c328d90.png\"\/><figcaption>\u041d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0438 \u043d\u0435\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0442\u043a\u0430<\/figcaption><\/figure>\n<p>\u041f\u0440\u0438\u0447\u0438\u043d\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b\u00a0\u2014 \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u0430\u044f \u0432\u0437\u0430\u0438\u043c\u043e\u0441\u0432\u044f\u0437\u044c \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u043c\u0435\u0436\u0434\u0443 \u043b\u0435\u0439\u0431\u043b\u0430\u043c\u0438. <\/p>\n<p>\u041f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0442\u0430\u043a:<\/p>\n<pre><code class=\"swift\">label1.snp.makeConstraints {     $0.top.horizontalEdges.equalToSuperview() }  label2.snp.makeConstraints {     $0.top.equalTo(label1.snp.bottom).offset(16)     $0.horizontalEdges.equalToSuperview() }  label3.snp.makeConstraints {     $0.top.equalTo(label2.snp.bottom).offset(16)     $0.horizontalEdges.bottom.equalToSuperview() }<\/code><\/pre>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/21e\/dea\/b04\/21edeab04485a50bba08aff7eb893408.png\" alt=\"\u041a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0438 \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0442\u043a\u0430\" title=\"\u041a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0438 \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0442\u043a\u0430\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/21e\/dea\/b04\/21edeab04485a50bba08aff7eb893408.png\"\/><figcaption>\u041a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u0435 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0438 \u043a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u0430\u044f \u0432\u0435\u0440\u0441\u0442\u043a\u0430<\/figcaption><\/figure>\n<p>\u041f\u043e\u043b\u0435\u0437\u043d\u0430 \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0430: \u043f\u0440\u0438\u00a0\u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u043f\u0440\u043e\u0434\u0443\u043c\u044b\u0432\u0430\u0442\u044c, \u043a\u0430\u043a\u043e\u0439 \u0434\u043e\u043b\u0436\u043d\u0430\u00a0\u0431\u044b\u0442\u044c \u0432\u0437\u0430\u0438\u043c\u043e\u0441\u0432\u044f\u0437\u044c \u043c\u0435\u0436\u0434\u0443 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438 \u043d\u0430\u00a0\u044d\u043a\u0440\u0430\u043d\u0435, \u043a\u0430\u043a\u043e\u0439 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 \u043d\u0430\u0438\u0431\u043e\u043b\u0435\u0435 \u0432\u0430\u0436\u0435\u043d, \u0447\u0442\u043e\u0431\u044b \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u0434\u0443\u043c\u043a\u0443 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u0430. \u041d\u0435\u00a0\u0441\u0442\u043e\u0438\u0442 \u0438\u0433\u043d\u043e\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u044e\u0449\u0438\u0435 \u0432\u043e\u043f\u0440\u043e\u0441\u044b, \u0432\u0441\u0435\u0433\u0434\u0430 \u043b\u0443\u0447\u0448\u0435 \u043f\u0440\u0438\u0439\u0442\u0438 \u043a\u00a0\u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u0443 \u0438 \u0443\u0442\u043e\u0447\u043d\u0438\u0442\u044c, \u043a\u0430\u043a\u043e\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 \u043c\u043e\u0436\u0435\u0442 \u0440\u0430\u0441\u0442\u044f\u0433\u0438\u0432\u0430\u0442\u044c\u0441\u044f, \u0430\u00a0\u0434\u043b\u044f\u00a0\u043a\u0430\u043a\u043e\u0433\u043e \u0441\u0442\u043e\u0438\u0442 \u0437\u0430\u0434\u0430\u0442\u044c \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u0432\u00a0\u0432\u0438\u0434\u0435 \u043a\u043e\u043d\u0441\u0442\u0430\u043d\u0442, \u0447\u0435\u043c \u043f\u043e\u0442\u043e\u043c \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u0442\u044c \u0441\u0442\u0440\u0430\u043d\u043d\u044b\u0439 UI.<\/p>\n<h4>\u041b\u043e\u0432\u0443\u0448\u043a\u0430 6: \u043d\u0435\u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u0440\u0430\u0437\u043d\u0438\u0446\u044b \u043c\u0435\u0436\u0434\u0443 left, right, top, bottom \u0438 leftMargin, rightMargin, topMargin, bottomMargin<\/h4>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0440\u0430\u0437\u043c\u0435\u0441\u0442\u0438\u043c \u0434\u0432\u0430 \u043a\u0432\u0430\u0434\u0440\u0430\u0442\u043d\u044b\u0445 \u0432\u044c\u044e \u0441\u043e\u0433\u043b\u0430\u0441\u043d\u043e \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f\u043c:<\/p>\n<pre><code class=\"swift\">view.addSubview(squareView1)  squareView1.snp.makeConstraints {   $0.centerY.equalToSuperview().offset(-100)   $0.size.equalTo(100)   $0.left.equalToSuperview() }  view.addSubview(squareView2)  squareView2.snp.makeConstraints {   $0.centerY.equalToSuperview().offset(100)   $0.size.equalTo(100)   $0.leadingMargin.equalToSuperview() }<\/code><\/pre>\n<p>\u041d\u0430\u00a0\u044d\u043a\u0440\u0430\u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/55e\/e04\/a99\/55ee04a99869a86146b6bf87d5756cf5.png\" alt=\"\u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 left \/ leadingMargin\" title=\"\u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 left \/ leadingMargin\" width=\"2500\" height=\"2540\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/55e\/e04\/a99\/55ee04a99869a86146b6bf87d5756cf5.png\"\/><figcaption>\u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 left \/ leadingMargin<\/figcaption><\/figure>\n<p>\u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u0432\u00a0\u0442\u043e\u043c, \u0447\u0442\u043e\u00a0\u0434\u043b\u044f\u00a0\u043a\u0440\u0430\u0441\u043d\u043e\u0433\u043e \u043a\u0432\u0430\u0434\u0440\u0430\u0442\u0430 \u043c\u044b \u0443\u043a\u0430\u0437\u0430\u043b\u0438 \u043f\u0440\u0438\u0432\u044f\u0437\u043a\u0443 \u043b\u0435\u0432\u043e\u0433\u043e \u043a\u0440\u0430\u044f (<code>left<\/code>) \u043d\u0430\u0448\u0435\u0433\u043e \u0432\u044c\u044e \u043a\u00a0\u043b\u0435\u0432\u043e\u043c\u0443 \u043a\u0440\u0430\u044e \u0435\u0433\u043e <code>superView<\/code>, \u0430\u00a0\u0434\u043b\u044f\u00a0\u0441\u0435\u0440\u043e\u0433\u043e \u043c\u044b \u0437\u0430\u0432\u044f\u0437\u0430\u043b\u0438\u0441\u044c \u043d\u0430 <code>leftMargin<\/code> \u0434\u043b\u044f\u00a0\u0432\u044c\u044e \u0438 \u0434\u043b\u044f\u00a0\u0435\u0433\u043e <code>superView<\/code>. <\/p>\n<p>\u0414\u0435\u043b\u043e \u0432\u00a0\u0442\u043e\u043c, \u0447\u0442\u043e <code>margin<\/code> \u0438\u043c\u0435\u044e\u0442 \u043e\u0442\u0441\u0442\u0443\u043f \u043e\u0442\u00a0\u043a\u0440\u0430\u044f \u0432\u044c\u044e \u0438 \u0435\u0441\u043b\u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432\u00a0\u0434\u0435\u0431\u0430\u0433\u0435\u0440\u0435, \u0442\u043e \u043c\u044b \u0443\u0432\u0438\u0434\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/5e4\/2c6\/06e\/5e42c606e6643f9cdbf1b481c08f34b0.png\" alt=\"LayoutMargins \u044d\u043a\u0440\u0430\u043d\u0430 \u0438 \u0441\u0435\u0440\u043e\u0433\u043e UIView\" title=\"LayoutMargins \u044d\u043a\u0440\u0430\u043d\u0430 \u0438 \u0441\u0435\u0440\u043e\u0433\u043e UIView\" width=\"2617\" height=\"2107\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5e4\/2c6\/06e\/5e42c606e6643f9cdbf1b481c08f34b0.png\"\/><figcaption>LayoutMargins \u044d\u043a\u0440\u0430\u043d\u0430 \u0438 \u0441\u0435\u0440\u043e\u0433\u043e UIView<\/figcaption><\/figure>\n<p>\u0423\u00a0\u0441\u0435\u0440\u043e\u0433\u043e \u0432\u044c\u044e \u0438 \u0443\u00a0\u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0433\u043e \u0432\u044c\u044e \u043d\u0430\u0448\u0435\u0433\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430 \u0435\u0441\u0442\u044c <code>LayoutMargins<\/code>. \u0414\u043b\u044f\u00a0\u0441\u0435\u0440\u043e\u0433\u043e <code>UIView<\/code> \u044d\u0442\u043e \u043a\u0432\u0430\u0434\u0440\u0430\u0442, \u0443\u043c\u0435\u043d\u044c\u0448\u0435\u043d\u043d\u044b\u0439 \u043d\u0430 8\u00a0\u0442\u043e\u0447\u0435\u043a \u0441\u00a0\u043a\u0430\u0436\u0434\u043e\u0439 \u0441\u0442\u043e\u0440\u043e\u043d\u044b, \u0434\u043b\u044f\u00a0\u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0433\u043e <code>UIView<\/code> \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043b\u0435\u0440\u0430\u00a0\u2014 \u043f\u0440\u044f\u043c\u043e\u0443\u0433\u043e\u043b\u044c\u043d\u0438\u043a \u0441\u00a0\u043e\u0442\u0441\u0442\u0443\u043f\u0430\u043c\u0438 16\u00a0\u0442\u043e\u0447\u0435\u043a \u0441\u043b\u0435\u0432\u0430 \u0438 \u0441\u043f\u0440\u0430\u0432\u0430, 47\u00a0\u0442\u043e\u0447\u0435\u043a \u0441\u0432\u0435\u0440\u0445\u0443 \u0438 34\u00a0\u0442\u043e\u0447\u043a\u0438 \u0441\u043d\u0438\u0437\u0443. \u0412\u00a0\u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0438 <code>$0.leadingMargin.equalToSuperview()<\/code> \u0432\u044b\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u043d\u0438\u0435 \u0438\u0434\u0451\u0442 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e <code>leadingMargin<\/code> \u043e\u0431\u043e\u0438\u0445 \u0432\u044c\u044e, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043e\u0442\u0441\u0442\u0443\u043f \u043e\u0442\u00a0\u043a\u0440\u0430\u044f \u0441\u0435\u0440\u043e\u0433\u043e \u043a\u0432\u0430\u0434\u0440\u0430\u0442\u0430 \u0434\u043e\u00a0\u043a\u0440\u0430\u044f \u0435\u0433\u043e <code>superView<\/code> \u0431\u0443\u0434\u0435\u0442 \u0432\u0441\u0435\u0433\u043e 8\u00a0\u0442\u043e\u0447\u0435\u043a (16\u00a0\u0442\u043e\u0447\u0435\u043a\u00a0\u2014 8\u00a0\u0442\u043e\u0447\u0435\u043a).<\/p>\n<p>\u0415\u0441\u043b\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e, \u0447\u0442\u043e\u0431\u044b \u043e\u0442\u0441\u0442\u0443\u043f \u0441\u0435\u0440\u043e\u0433\u043e \u043a\u0432\u0430\u0434\u0440\u0430\u0442\u0430 \u0437\u0430\u0432\u0438\u0441\u0435\u043b \u043e\u0442\u00a0leadingMargin \u0435\u0433\u043e superView, \u043d\u043e\u00a0\u043d\u0435\u00a0\u0443\u043c\u0435\u043d\u044c\u0448\u0430\u043b \u0435\u0433\u043e, \u0442\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043e\u0442\u043a\u043e\u0440\u0440\u0435\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u043f\u0438\u0441\u044c:<\/p>\n<pre><code class=\"swift\">squareView2.snp.makeConstraints {     $0.centerY.equalToSuperview().offset(100)     $0.size.equalTo(100)     $0.leading.equalTo(view.snp.leadingMargin) }<\/code><\/pre>\n<p>\u0422\u0443\u0442 \u043c\u044b \u0437\u0430\u0434\u0430\u0451\u043c, \u0447\u0442\u043e \u0434\u043b\u044f squareView2 \u0431\u0443\u0434\u0435\u0442 \u0443\u0447\u0438\u0442\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u0435\u0433\u043e <code>leading<\/code> \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440, \u0430 \u0434\u043b\u044f \u0435\u0433\u043e <code>superView<\/code> \u2013 <code>leadingMargin<\/code>.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/02e\/458\/ce9\/02e458ce9b09f31866cf4f7907136141.png\" alt=\"\u041b\u0435\u0432\u044b\u0439 \u043a\u0440\u0430\u0439 \u0434\u043e\u0447\u0435\u0440\u043d\u0435\u0439 UIView \u0437\u0430\u0432\u0438\u0441\u0438\u043e\u0442 \u043e\u0442 \u043b\u0435\u0432\u043e\u0433\u043e LayoutMargin \u044d\u043a\u0440\u0430\u043d\u0430\" title=\"\u041b\u0435\u0432\u044b\u0439 \u043a\u0440\u0430\u0439 \u0434\u043e\u0447\u0435\u0440\u043d\u0435\u0439 UIView \u0437\u0430\u0432\u0438\u0441\u0438\u043e\u0442 \u043e\u0442 \u043b\u0435\u0432\u043e\u0433\u043e LayoutMargin \u044d\u043a\u0440\u0430\u043d\u0430\" width=\"2617\" height=\"2107\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/02e\/458\/ce9\/02e458ce9b09f31866cf4f7907136141.png\"\/><figcaption>\u041b\u0435\u0432\u044b\u0439 \u043a\u0440\u0430\u0439 \u0434\u043e\u0447\u0435\u0440\u043d\u0435\u0439 UIView \u0437\u0430\u0432\u0438\u0441\u0438\u043e\u0442 \u043e\u0442 \u043b\u0435\u0432\u043e\u0433\u043e LayoutMargin \u044d\u043a\u0440\u0430\u043d\u0430<\/figcaption><\/figure>\n<h4>\u0415\u0449\u0451 \u0440\u0430\u0437 \u043f\u0440\u043e LayoutConstraints<\/h4>\n<p>\u0412\u00a0\u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043c\u043d\u043e\u0433\u043e \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u043b\u0430 \u043e\u0448\u0438\u0431\u043a\u0438 <code>LayoutConstraints<\/code>. \u0427\u0430\u0441\u0442\u043e \u0438\u0445 \u043f\u043e\u044f\u0432\u043b\u0435\u043d\u0438\u0435 \u043d\u0435\u00a0\u0441\u043e\u043f\u0440\u043e\u0432\u043e\u0436\u0434\u0430\u0435\u0442\u0441\u044f \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u043c\u0438 \u043e\u0448\u0438\u0431\u043a\u0430\u043c\u0438 \u0432\u0451\u0440\u0441\u0442\u043a\u0438, \u043d\u043e\u00a0\u043e\u043d\u0438 \u0437\u0430\u0431\u0438\u0432\u0430\u044e\u0442 \u0441\u043e\u0431\u043e\u0439 \u043a\u043e\u043d\u0441\u043e\u043b\u044c \u0438 \u044d\u0442\u0438\u043c \u043c\u0435\u0448\u0430\u044e\u0442 \u043f\u043e\u0438\u0441\u043a\u0443 \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u043e\u043b\u0435\u0437\u043d\u043e\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u0442\u0430\u043c, \u0430\u00a0\u0442\u0430\u043a\u0436\u0435 \u043c\u043e\u0433\u0443\u0442 \u0432\u044b\u0441\u0442\u0440\u0435\u043b\u0438\u0442\u044c \u0432\u00a0\u0441\u0430\u043c\u044b\u0439 \u043d\u0435\u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0439 \u043c\u043e\u043c\u0435\u043d\u0442. <\/p>\n<p>\u0414\u043b\u044f\u00a0\u043f\u043e\u0438\u0441\u043a\u0430 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0430 \u043e\u0448\u0438\u0431\u043e\u043a \u043f\u043e\u0441\u043e\u0432\u0435\u0442\u0443\u044e \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043c\u0435\u0442\u043e\u0434\u043e\u043c <code>labeled(:_)<\/code> \u043f\u0440\u0438\u00a0\u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u043e\u043d \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c <code>identifier<\/code> \u0434\u043b\u044f <code>NSLayoutConstraint<\/code>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u0442\u043e\u043c \u0431\u0443\u0434\u0435\u0442 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0442\u044c\u0441\u044f \u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u0432\u00a0\u0441\u043b\u0443\u0447\u0430\u0435 \u0432\u043e\u0437\u043d\u0438\u043a\u043d\u043e\u0432\u0435\u043d\u0438\u044f \u043e\u0448\u0438\u0431\u043e\u043a \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432.<\/p>\n<h3>\u0421\u043f\u0430\u0441\u0430\u0435\u043c \u043a\u043e\u043d\u0441\u043e\u043b\u044c \u043e\u0442 \u043f\u0440\u043e\u0441\u0442\u044b\u043d\u0438 \u043e\u0448\u0438\u0431\u043e\u043a: \u0430 \u0442\u043e\u0447\u043d\u043e \u043b\u0438 \u043e\u043d\u043e \u043d\u0443\u0436\u043d\u043e?\u00a0\u00a0<\/h3>\n<p>\u0413\u043b\u0430\u0432\u043d\u044b\u0439 \u0441\u043e\u0432\u0435\u0442 \u0432\u00a0\u0431\u043e\u0440\u044c\u0431\u0435 \u0441\u00a0\u043e\u0448\u0438\u0431\u043a\u0430\u043c\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u043c\u0430\u043a\u0435\u0442\u0430 \u0432\u00a0SnapKit \u044f \u0441\u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u043b\u0430 \u0434\u043b\u044f\u00a0\u0441\u0435\u0431\u044f \u0442\u0430\u043a: \u0432\u0441\u0435\u0433\u0434\u0430 \u0437\u0430\u0434\u0430\u0432\u0430\u0442\u044c \u0441\u0435\u0431\u0435 \u0434\u0432\u0430 \u043f\u0440\u043e\u0432\u0435\u0440\u043e\u0447\u043d\u044b\u0445 \u0432\u043e\u043f\u0440\u043e\u0441\u0430: \u00ab\u0410 \u0442\u043e\u0447\u043d\u043e \u043e\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e?\u00bb \u0438 \u00ab\u0410 \u0442\u043e\u0447\u043d\u043e\u00a0\u043b\u0438 \u043e\u043d\u043e \u043d\u0443\u0436\u043d\u043e?\u00bb.\u00a0\u0416\u0435\u043b\u0430\u043d\u0438\u0435 \u043e\u0444\u043e\u0440\u043c\u043b\u044f\u0442\u044c \u043a\u043e\u0434 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u043f\u043e\u00a0\u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c\u0443\u00a0\u2014 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e\u0435 \u0441\u0442\u0440\u0435\u043c\u043b\u0435\u043d\u0438\u0435. \u041d\u043e\u00a0\u0435\u0441\u043b\u0438 \u0434\u0435\u043b\u0430\u0435\u0448\u044c \u043d\u0435\u00a0\u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u044b\u0439 UI \u0438\u043b\u0438\u00a0\u0442\u0432\u043e\u0451 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043d\u0435\u00a0\u0440\u0430\u0441\u0441\u0447\u0438\u0442\u0430\u043d\u043e \u043d\u0430\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043b\u044e\u0434\u0435\u0439 \u0441\u00a0\u0434\u0440\u0443\u0433\u0438\u043c \u043d\u0430\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u0435\u043c \u043f\u0438\u0441\u044c\u043c\u0430\u00a0\u2014 \u043c\u043d\u043e\u0433\u043e\u0435 \u0438\u0437\u00a0\u043e\u043f\u0438\u0441\u0430\u043d\u043d\u043e\u0433\u043e \u0432\u044b\u0448\u0435 \u043c\u043e\u0436\u0435\u0442 \u043f\u0440\u0438\u0432\u0435\u0441\u0442\u0438 \u043a\u00a0\u043e\u0432\u0435\u0440\u0438\u043d\u0436\u0438\u043d\u0438\u0440\u0438\u043d\u0433\u0443, \u0443\u043b\u0443\u0447\u0448\u0435\u043d\u0438\u044f\u043c \u0440\u0430\u0434\u0438 \u0443\u043b\u0443\u0447\u0448\u0435\u043d\u0438\u0439. \u0410\u00a0\u0442\u043e\u0447\u043d\u043e\u00a0\u043b\u0438 \u043e\u043d\u043e \u043d\u0443\u0436\u043d\u043e? <\/p>\n<p>\u0417\u0430\u0442\u043e \u0435\u0441\u043b\u0438 UI \u043d\u0430\u0441\u044b\u0449\u0435\u043d\u043d\u044b\u0439 \u0438 \u0434\u0440\u0443\u0433\u0438\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0435 \u043a\u0440\u0430\u0435\u0432\u044b\u0435 \u0441\u043b\u0443\u0447\u0430\u0438 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b, \u0442\u043e\u0433\u0434\u0430 \u0442\u043e\u0447\u043d\u043e \u0441\u0442\u043e\u0438\u0442 \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c \u043c\u0438\u043d\u0438\u043c\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439 \u043f\u043e\u0434\u00a0\u043a\u0430\u043f\u043e\u0442\u043e\u043c, \u0434\u043b\u044f\u00a0\u0443\u0441\u043a\u043e\u0440\u0435\u043d\u0438\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430.<\/p>\n<p>\u041a\u0430\u043a\u043e\u0439 \u0443\u00a0\u0432\u0430\u0441 \u043e\u043f\u044b\u0442 \u0441\u043e SnapKit? \u0420\u0430\u0441\u0441\u043a\u0430\u0436\u0438\u0442\u0435 \u0432\u00a0\u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u0445! <\/p>\n<\/p>\n<\/div>\n<\/div>\n<\/div>\n<p> <!----> <!----><\/div>\n<p> <!----> <!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/company\/sravni\/blog\/719474\/\"> https:\/\/habr.com\/ru\/company\/sravni\/blog\/719474\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041f\u0440\u0438\u0432\u0435\u0442, \u044f \u0414\u0430\u0448\u0430, \u0437\u0430\u043d\u0438\u043c\u0430\u044e\u0441\u044c iOS\u2011\u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u043e\u0439 \u0432\u00a0\u0421\u0440\u0430\u0432\u043d\u0438. \u041c\u044b \u0432\u00a0\u043c\u043e\u0431\u0438\u043b\u044c\u043d\u043e\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u0435 \u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u0441\u044f SnapKit\u00a0\u2014 \u043f\u043e\u043c\u043e\u0433\u0430\u0435\u0442 \u043d\u0430\u043c \u0440\u0435\u0432\u044c\u044e\u0438\u0442\u044c \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0432\u00a0\u043e\u0431\u0449\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u0445\u00a0\u0431\u044b\u0441\u0442\u0440\u0435\u0435 \u0438 \u043f\u0440\u043e\u0449\u0435. \u0418\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u0439, \u043d\u043e\u00a0\u044f \u0437\u0430\u043c\u0435\u0442\u0438\u043b\u0430 \u0442\u0435\u043d\u0434\u0435\u043d\u0446\u0438\u044e: \u0441\u0442\u043e\u0438\u0442 \u0432\u00a0\u0440\u0430\u0431\u043e\u0442\u0435 \u043f\u043e\u044f\u0432\u0438\u0442\u044c\u0441\u044f \u0441\u043b\u043e\u0436\u043d\u044b\u043c \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u0430\u043c \u0432\u0451\u0440\u0441\u0442\u043a\u0438, \u043a\u0430\u043a\u00a0\u0441\u0440\u0430\u0437\u0443 \u0432\u00a0\u0440\u0430\u0437\u044b \u0440\u0430\u0441\u0442\u0451\u0442 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c, \u0447\u0442\u043e\u00a0UI \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u043e\u043a, \u0430\u00a0\u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u0431\u0443\u0434\u0435\u0442 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0442\u044c\u0441\u044f \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u043e\u0448\u0438\u0431\u043e\u043a LayoutConstraints, \u043b\u043e\u0433\u0438 \u0437\u0430\u0441\u043e\u0440\u044f\u044e\u0442\u0441\u044f, \u043d\u0430\u0439\u0442\u0438 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u043e\u043b\u0435\u0437\u043d\u0443\u044e \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0441\u043b\u043e\u0436\u043d\u0435\u0435. <\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0412\u00a0\u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0441\u043f\u0430\u0441\u0442\u0438 \u043b\u043e\u0433\u0438 \u043e\u0442\u00a0\u043e\u0448\u0438\u0431\u043e\u043a \u043a\u043e\u043d\u0441\u0442\u0440\u0435\u0439\u043d\u0442\u043e\u0432, \u043e\u0431\u0441\u0443\u0434\u0438\u043c \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0438 \u0443\u0434\u043e\u0431\u043d\u044b\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u044b \u0434\u043b\u044f\u00a0\u0440\u0430\u0431\u043e\u0442\u044b \u0441\u00a0\u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f\u043c\u0438, \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u043c \u043a\u0440\u0430\u0435\u0432\u044b\u0435 \u0441\u043b\u0443\u0447\u0430\u0438 \u0438 \u0432\u043c\u0435\u0441\u0442\u0435 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0447\u0443\u0442\u044c \u0433\u043b\u0443\u0431\u0436\u0435 \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c\u0441\u044f \u0432\u00a0\u0442\u043e\u043d\u043a\u043e\u0441\u0442\u044f\u0445 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u043e SnapKit.<\/p>\n<h3>\u0422\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 SnapKit<\/h3>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0441\u0432\u0435\u0440\u0438\u043c\u0441\u044f, \u0447\u0442\u043e\u00a0\u0433\u043e\u0432\u043e\u0440\u0438\u043c \u043e\u0431\u00a0\u043e\u0434\u043d\u043e\u043c \u0438 \u0442\u043e\u043c\u00a0\u0436\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0435. <a href=\"https:\/\/github.com\/SnapKit\/SnapKit\"><u>SnapKit<\/u><\/a>\u00a0\u2014 \u044d\u0442\u043e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430, \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0449\u0430\u044f \u0441\u0438\u043d\u0442\u0430\u043a\u0441\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0441\u0430\u0445\u0430\u0440 \u0438 \u043e\u0431\u0435\u0440\u0442\u043a\u0438 \u0434\u043b\u044f\u00a0\u0431\u043e\u043b\u0435\u0435 \u0443\u0434\u043e\u0431\u043d\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u00a0\u043a\u043b\u0430\u0441\u0441\u043e\u043c NSLayoutConstraint, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0449\u0438\u043c \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0432\u0437\u0430\u0438\u043c\u043d\u043e\u0435 \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430.<\/p>\n<p>\u041f\u0435\u0440\u0432\u044b\u0439 \u0440\u0435\u043b\u0438\u0437 SnapKit \u0441\u043b\u0443\u0447\u0438\u043b\u0441\u044f \u0435\u0449\u0451 \u0432\u00a0\u0434\u0430\u043b\u0451\u043a\u043e\u043c 2016\u00a0\u0438 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b\u0441\u044f \u043f\u043e\u0434\u00a0Swift 2.3; \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u0440\u0435\u043b\u0438\u0437 5.6.0\u00a0\u0432\u044b\u0448\u0435\u043b \u0432\u00a0\u0430\u043f\u0440\u0435\u043b\u0435 2022\u00a0\u0438 \u0443\u043c\u0435\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u0441\u00a0Swift 5.6. <\/p>\n<p>\u0417\u0430\u00a0\u0432\u0440\u0435\u043c\u044f \u0441\u0432\u043e\u0435\u0433\u043e \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043e\u0432\u0430\u043d\u0438\u044f \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u043e\u0431\u0440\u0435\u043b\u0430 \u043d\u0430\u0440\u043e\u0434\u043d\u0443\u044e \u043b\u044e\u0431\u043e\u0432\u044c. \u0412\u044b \u043b\u0435\u0433\u043a\u043e \u043d\u0430\u0439\u0434\u0451\u0442\u0435 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e \u0441\u0442\u0430\u0442\u0435\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0434\u043e\u043f\u043e\u043b\u043d\u044f\u044e\u0442 <a href=\"https:\/\/snapkit.github.io\/SnapKit\/docs\/\"><u>\u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u044c\u043d\u0443\u044e \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e<\/u><\/a> \u0432\u0438\u0437\u0443\u0430\u043b\u044c\u043d\u044b\u043c \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043e\u043c (\u043f\u0438\u0448\u0438\u0442\u0435, \u0435\u0441\u043b\u0438 \u043d\u0443\u0436\u043d\u044b \u0431\u0443\u0434\u0443\u0442 \u043d\u0430\u0432\u043e\u0434\u043a\u0438). <\/p>\n<p>\u0412\u00a0\u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u0440\u0435\u0448\u0438\u043b\u0430 \u043f\u043e\u0439\u0442\u0438 \u043f\u043e\u0445\u043e\u0436\u0438\u043c, \u043d\u043e\u00a0\u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0434\u0440\u0443\u0433\u0438\u043c \u043f\u0443\u0442\u0451\u043c: \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0435 \u0438\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0438 \u043e\u0448\u0438\u0431\u043e\u043a \u0434\u043b\u044f\u00a0\u043d\u0435\u0442\u0440\u0438\u0432\u0438\u0430\u043b\u044c\u043d\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u0432\u0451\u0440\u0441\u0442\u043a\u0438 \u0438 \u0437\u0430\u00a0\u0441\u0447\u0435\u0442 \u044d\u0442\u043e\u0433\u043e \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c\u0441\u044f, \u043f\u043e\u0447\u0435\u043c\u0443 \u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u043c\u043e\u0436\u0435\u0442 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0442\u044c\u0441\u044f \u043c\u043d\u043e\u0433\u043e \u043e\u0448\u0438\u0431\u043e\u043a, \u0445\u043e\u0442\u044f UI \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0442\u0430\u043a, \u043a\u0430\u043a\u00a0\u043e\u0436\u0438\u0434\u0430\u0435\u0442\u0441\u044f.<\/p>\n<p>\u0412\u0441\u0435\u043c \u0437\u043d\u0430\u043a\u043e\u043c\u044b \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u0438, \u043a\u043e\u0433\u0434\u0430 \u043d\u0430\u0434\u043e \u0432\u00a0\u0441\u0436\u0430\u0442\u044b\u0435 \u0441\u0440\u043e\u043a\u0438 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043a\u0430\u043a\u0443\u044e\u2011\u0442\u043e \u0444\u0438\u0447\u0443, \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u044f \u043d\u043e\u0432\u044b\u0435 \u0434\u043b\u044f\u00a0\u0442\u0435\u0431\u044f \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0438. \u0412\u0440\u0435\u043c\u0435\u043d\u0438 \u043d\u0430\u00a0\u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u0435 \u0432\u043e\u043e\u0431\u0449\u0435 \u0432\u0441\u0435\u0445 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u043d\u0435\u00a0\u0432\u0441\u0435\u0433\u0434\u0430 \u0445\u0432\u0430\u0442\u0430\u0435\u0442\u00a0\u2014 \u0432\u00a0\u0442\u0430\u043a\u0438\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445 \u0435\u0441\u043b\u0438 \u0432\u00a0\u0441\u043e\u0441\u0435\u0434\u043d\u0435\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u0435 \u0443\u0436\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0430\u0441\u044c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0430\u044f \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u044f, \u0441\u043c\u043e\u0442\u0440\u0438\u043c, \u043a\u0430\u043a\u00a0\u044d\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u043b\u0438 \u043a\u043e\u043b\u043b\u0435\u0433\u0438, \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u043c.<\/p>\n<p>\u0412\u0441\u0451\u00a0\u0431\u044b \u0445\u043e\u0440\u043e\u0448\u043e, \u043d\u043e\u00a0\u0431\u044b\u0432\u0430\u0435\u0442, \u0447\u0442\u043e\u00a0\u043e\u043f\u044b\u0442 \u043a\u043e\u043b\u043b\u0435\u0433 \u043d\u0435\u00a0\u0443\u0434\u0430\u0451\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0432\u00a0\u043f\u043e\u043b\u043d\u043e\u0439 \u043c\u0435\u0440\u0435\u00a0\u2014 \u0434\u0440\u0443\u0433\u0438\u0435 \u0432\u0432\u043e\u0434\u043d\u044b\u0435, \u043d\u0430\u0448\u0430 \u0444\u0438\u0447\u0430 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0431\u043e\u043b\u044c\u0448\u0435\u0433\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0441\u00a0\u0438\u0445 \u0431\u043e\u043b\u0435\u0435 \u0441\u043b\u043e\u0436\u043d\u043e\u0439 \u0432\u0437\u0430\u0438\u043c\u043e\u0441\u0432\u044f\u0437\u044c\u044e. \u0418\u043b\u0438\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0442\u0430\u043a\u0438\u043c \u043f\u0440\u043e\u0441\u0442\u044b\u043c, \u0447\u0442\u043e\u00a0\u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0447\u0442\u043e\u00a0\u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e \u0437\u0434\u0435\u0441\u044c \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435\u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u00a0\u2014 \u0440\u0438\u0441\u043a\u0443\u0435\u0448\u044c \u0440\u0430\u0441\u0441\u043b\u0430\u0431\u0438\u0442\u044c\u0441\u044f \u0438 \u0443\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043a\u0440\u0430\u0435\u0432\u044b\u0435 \u0441\u043b\u0443\u0447\u0430\u0438. <\/p>\n<p>\u041f\u0440\u0438\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 SnapKit \u0443\u00a0\u043c\u0435\u043d\u044f \u0447\u0430\u0441\u0442\u043e \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u043b\u0438 \u0432\u043e\u043f\u0440\u043e\u0441\u044b, \u043a\u0430\u043a\u00a0\u044d\u0442\u043e \u0432\u0441\u0451 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u0438 \u043c\u043e\u0436\u043d\u043e\u00a0\u043b\u0438 \u0434\u043e\u0441\u0442\u0438\u0447\u044c \u0442\u0430\u043a\u043e\u0433\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438, \u0447\u0442\u043e\u0431\u044b \u0434\u0430\u0436\u0435 \u0431\u0435\u0437\u00a0\u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u043f\u0440\u0438\u043b\u043e\u0436\u0435\u043d\u0438\u044f \u0441\u043a\u0430\u0437\u0430\u0442\u044c: \u0432\u043e\u0442 \u0437\u0434\u0435\u0441\u044c \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e, \u0430\u00a0\u0437\u0434\u0435\u0441\u044c \u0432\u0435\u0440\u0441\u0442\u043a\u0430 \u043f\u043e\u043f\u043b\u044b\u0432\u0451\u0442. \u0412\u0434\u043e\u0431\u0430\u0432\u043e\u043a \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044f \u0441\u00a0\u043f\u043e\u0440\u0442\u044f\u043d\u043a\u043e\u0439 \u043e\u0448\u0438\u0431\u043e\u043a LayoutConstraints \u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438 \u043f\u0440\u0438\u043d\u043e\u0441\u0438\u0442 \u043e\u0449\u0443\u0449\u0435\u043d\u0438\u0435 \u043d\u0435\u0430\u043a\u043a\u0443\u0440\u0430\u0442\u043d\u043e\u0441\u0442\u0438. \u0412\u0441\u0451 \u044d\u0442\u043e \u043f\u043e\u0434\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u043e \u043c\u0435\u043d\u044f \u043a\u00a0\u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u044e \u043a\u0440\u0430\u0435\u0432\u044b\u0445 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u0432\u00a0\u0440\u0430\u0431\u043e\u0442\u0435 SnapKit; \u043e\u00a0\u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u0430\u0445 \u0445\u043e\u0447\u0443 \u0432\u0430\u043c \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u0430\u0442\u044c \u0432\u00a0\u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435.<\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u043d\u0430\u0432\u043e\u0434\u0438\u0442\u044c \u043f\u043e\u0440\u044f\u0434\u043e\u043a \u0441\u043e SnapKit. <\/p>\n<h3>\u0411\u043e\u043b\u044c\u0448\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432\u00a0\u00a0<\/h3>\n<p>\u041f\u0435\u0440\u0432\u044b\u043c \u0434\u0435\u043b\u043e\u043c \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u044e \u0440\u0430\u0441\u0448\u0438\u0440\u0438\u0442\u044c \u0441\u043f\u0438\u0441\u043e\u043a \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0445 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432, \u0441\u00a0\u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0441\u043e\u0437\u0434\u0430\u044e\u0442\u0441\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f Layout. \u0421\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u044b \u044f \u0441\u043e\u0431\u0440\u0430\u043b\u0430 \u0432\u00a0\u0442\u0430\u0431\u043b\u0438\u0446\u0435 1; \u0435\u0449\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0437\u0432\u0430\u0442\u044c \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u043c\u0438\u00a0\u2014 \u0432\u00a0\u0442\u0430\u0431\u043b\u0438\u0446\u0435 2.<\/p>\n<details class=\"spoiler\">\n<summary>\u0422\u0430\u0431\u043b\u0438\u0446\u0430 1<\/summary>\n<div class=\"spoiler__content\">\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td>\n<p align=\"left\">ViewAttribute<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutAttribute<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.left<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.left<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.right<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.right<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.top<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.top<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.bottom<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.bottom<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.leading<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.leading<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.trailing<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.trailing<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.width<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.width<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.height<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.height<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.centerX<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.centerX<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.centerY<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.centerY<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.lastBaseline<\/p>\n<\/td>\n<td>\n<p align=\"left\">NSLayoutConstraint.Attribute.lastBaseline<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<\/div>\n<\/details>\n<details class=\"spoiler\">\n<summary>\u0422\u0430\u0431\u043b\u0438\u0446\u0430 2<\/summary>\n<div class=\"spoiler__content\">\n<div>\n<div class=\"table\">\n<table>\n<tbody>\n<tr>\n<td>\n<p align=\"left\">ViewAttribute<\/p>\n<\/td>\n<td>\n<p align=\"left\">\u041e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u0435\u043c\u044b\u0435 ViewAttribute<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.edge<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.horizontalEdges, view.snp.verticalEdges<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.horizontalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.left, view.snp.right<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.verticalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.top, view.snp.bottom<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.directionalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.directionalHorizontalEdges, view.snp.directionalVerticalEdges<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.directionalHorizontalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.leading, view.snp.trailing<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.directionalVerticalEdges<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.top, view.snp.bottom<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.size<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.width, view.snp.height<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.center<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.centerX, view.snp.centerY<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.margins<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.leftMargin, view.snp.rightMargin,\u00a0 view.snp.topMargin, view.snp.bottomMargin<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.directionalMargins<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.leadingMargin, view.snp.trailingMargin, view.snp.topMargin, view.snp.bottomMargin<\/p>\n<\/td>\n<\/tr>\n<tr>\n<td>\n<p align=\"left\">view.snp.centerWithinMargins<\/p>\n<\/td>\n<td>\n<p align=\"left\">view.snp.centerXWithinMargins, view.snp.centerYWithinMargins<\/p>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<\/div>\n<\/details>\n<p>\u041e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b \u043d\u0443\u0436\u043d\u044b, \u0447\u0442\u043e\u0431\u044b \u0441\u043e\u043a\u0440\u0430\u0442\u0438\u0442\u044c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043a\u043e\u0434\u0430 \u043f\u0440\u0438\u00a0\u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439, \u0430\u00a0\u0442\u0430\u043a\u0436\u0435 \u0434\u043b\u044f\u00a0\u0443\u043f\u0440\u043e\u0449\u0435\u043d\u0438\u044f \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u044f, \u0447\u0442\u043e\u00a0\u043c\u044b \u0445\u043e\u0442\u0435\u043b\u0438 \u0432\u0441\u0435\u043c \u044d\u0442\u0438\u043c \u0441\u043a\u0430\u0437\u0430\u0442\u044c.<\/p>\n<h3>\u0427\u0442\u043e \u043f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u043e\u043c SnapKit, \u043d\u0430 \u043f\u0440\u0438\u043c\u0435\u0440\u0435<\/h3>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0437\u0430\u0433\u043b\u044f\u043d\u0435\u043c \u0432\u0433\u043b\u0443\u0431\u044c SnapKit. \u0415\u0441\u043b\u0438 \u0445\u043e\u0442\u0438\u0442\u0435 \u0441\u0440\u0430\u0437\u0443 \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u043a\u00a0\u0440\u0430\u0437\u0431\u043e\u0440\u0443 \u043f\u0440\u0438\u0447\u0438\u043d <a href=\"#UIProblems\">\u043e\u0448\u0438\u0431\u043e\u043a \u0434\u043b\u044f\u00a0\u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/a> (\u0433\u043b\u0430\u0432\u043d\u043e\u0435, \u0440\u0430\u0434\u0438 \u0447\u0435\u0433\u043e \u043c\u044b \u0437\u0434\u0435\u0441\u044c!), \u043c\u043e\u0436\u0435\u0442\u0435 \u0441\u043c\u0435\u043b\u043e \u043f\u0440\u043e\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u044d\u0442\u0443 \u0447\u0430\u0441\u0442\u044c \u0441\u0442\u0430\u0442\u044c\u0438. \u0415\u0441\u043b\u0438\u00a0\u0436\u0435 \u0445\u043e\u0447\u0435\u0442\u0441\u044f \u043e\u0441\u0432\u0435\u0436\u0438\u0442\u044c \u0432\u00a0\u043f\u0430\u043c\u044f\u0442\u0438 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438, \u0442\u043e\u0433\u0434\u0430 \u043f\u043e\u0435\u0445\u0430\u043b\u0438.<\/p>\n<p>\u0412\u00a0SnapKit \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0442 \u0442\u0440\u0438 \u043f\u0443\u0431\u043b\u0438\u0447\u043d\u044b\u0445 \u043c\u0435\u0442\u043e\u0434\u0430, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0449\u0438\u0445 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c \u0441\u043f\u0438\u0441\u043a\u043e\u043c \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 (LayoutConstraints):<\/p>\n<ul>\n<li>\n<p><code>makeConstraints(_ closure:)<\/code>; <\/p>\n<\/li>\n<li>\n<p><code>remakeConstraints(_ closure:)<\/code>; <\/p>\n<\/li>\n<li>\n<p><code>updateConstraints(_ closure:)<\/code>. <\/p>\n<\/li>\n<\/ul>\n<p>\u0415\u0449\u0451 \u0435\u0441\u0442\u044c \u0447\u0435\u0442\u0432\u0451\u0440\u0442\u044b\u0439 \u043c\u0435\u0442\u043e\u0434\u00a0\u2014 <code>removeConstraints()<\/code>; \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043e\u0447\u0438\u0441\u0442\u0438\u0442\u044c \u0441\u043f\u0438\u0441\u043e\u043a \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u0443\u00a0\u0432\u044b\u0431\u0440\u0430\u043d\u043d\u043e\u0433\u043e \u0432\u044c\u044e.<\/p>\n<p>\u041f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u043f\u043e\u043c\u0435\u0441\u0442\u0438\u0442\u044c \u043a\u043d\u043e\u043f\u043a\u0443 <code>button<\/code> \u043f\u043e\u00a0\u0446\u0435\u043d\u0442\u0440\u0443 \u0435\u0435 <code>superView<\/code>. \u0422\u043e\u0433\u0434\u0430 \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0443\u044e \u0437\u0430\u043f\u0438\u0441\u044c:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {   $0.center.equalToSuperview() }<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u0443\u0433\u043b\u0443\u0431\u0438\u0442\u044c\u0441\u044f \u0432\u00a0\u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e, \u0442\u043e \u0432\u00a0\u043c\u0435\u0442\u043e\u0434\u0435 <code>makeConstraints(_ closure:)<\/code> \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0432\u044b\u0437\u043e\u0432 \u043c\u0435\u0442\u043e\u0434\u0430 <code>makeConstraints(item:, closure:)<\/code> \u043a\u043b\u0430\u0441\u0441\u0430 <code>ConstraintMaker<\/code> (\u043f\u043e\u0434\u043e\u0431\u0438\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u0430 \u0444\u0430\u0441\u0430\u0434), \u0432\u00a0\u043a\u043e\u0442\u043e\u0440\u043e\u043c \u043c\u044b \u0443\u0432\u0438\u0434\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f:<\/p>\n<p>1. \u0418\u0437\u00a0\u043d\u0430\u0448\u0435\u0439 \u043a\u043d\u043e\u043f\u043a\u0438 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 <code>ConstraintMaker<\/code>, \u0432\u00a0\u0445\u043e\u0434\u0435 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0430\u0448\u0435\u0439 \u043a\u043d\u043e\u043f\u043a\u0438 \u0432\u044b\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f <code>translatesAutoresizingMaskIntoConstraints = false<\/code>, \u0434\u043b\u044f\u00a0\u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u0434\u0430\u043b\u0435\u0435 \u0438\u043c\u0435\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u043d\u0430\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0442\u044c <code>NSLayoutConstraint<\/code>.<\/p>\n<p>2. \u0414\u0430\u043b\u0435\u0435 \u043e\u0431\u0440\u0430\u0442\u043d\u043e \u0432\u00a0\u0437\u0430\u043c\u044b\u043a\u0430\u043d\u0438\u0435 \u043f\u0435\u0440\u0435\u0434\u0430\u0451\u0442\u0441\u044f ConstraintMaker, \u0433\u0434\u0435 \u043c\u044b \u0435\u0433\u043e \u043e\u0431\u043e\u0433\u0430\u0449\u0430\u0435\u043c \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u043c\u0438 <code>ConstraintMakerExtendable<\/code>: <code>center<\/code>, <code>size<\/code>, <code>edges<\/code> \u0438 \u043f\u0440\u043e\u0447\u0438\u043c.<\/p>\n<p>\u041a\u0430\u0436\u0434\u0430\u044f \u0441\u0442\u0440\u043e\u043a\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u0437\u0430\u043c\u044b\u043a\u0430\u043d\u0438\u044f \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u0432\u00a0\u0432\u044b\u0437\u043e\u0432\u0443 \u043c\u0435\u0442\u043e\u0434\u0430 <code>makeExtendableWithAttributes(_:)<\/code> (\u0432 \u043d\u0430\u0448\u0435\u043c \u043f\u0440\u0438\u043c\u0435\u0440\u0435 \u0434\u043b\u044f\u00a0\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430 center), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442 \u0432\u00a0\u0441\u043f\u0438\u0441\u043e\u043a descriptions \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0430 <code>ConstraintMaker<\/code> \u043e\u0431\u044a\u0435\u043a\u0442 <code>ConstraintDescription<\/code> (\u043a\u043b\u0430\u0441\u0441 \u0441\u00a0\u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435\u043c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u043e\u0432 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f) \u0441\u00a0\u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u043c, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u043c \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u043c\u0443 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044e (\u043b\u0438\u0431\u043e \u0441\u00a0\u043d\u0430\u0431\u043e\u0440\u043e\u043c \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u0432, \u0435\u0441\u043b\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u043c), \u0430\u00a0\u0434\u0430\u043b\u044c\u0448\u0435 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u043e\u0431\u044a\u0435\u043a\u0442 <code>ConstraintMakerExtendable<\/code>, \u043d\u0430\u0441\u043b\u0435\u0434\u043d\u0438\u043a\u0430 <code>ConstraintMakerRelatable<\/code>. <\/p>\n<p>\u0412\u00a0\u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435, center \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u043c \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u043c, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432\u00a0ConstraintDescription \u0431\u0443\u0434\u0435\u0442 \u043f\u0435\u0440\u0435\u0434\u0430\u043d <code>OptionSet<\/code> <code>[.centerX, .centerY]<\/code>.<\/p>\n<p>3. \u041f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e, \u043a\u0430\u043a\u00a0\u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u0430\u043d \u0430\u0442\u0440\u0438\u0431\u0443\u0442 center, \u0434\u043b\u044f\u00a0\u043d\u0435\u0433\u043e \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043c\u0435\u0442\u043e\u0434 <code>equalToSuperview()<\/code>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u043a\u00a0\u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0430 <code>ConstraintMakerEditable<\/code>. <\/p>\n<p><code>ConstraintMakerEditable<\/code> \u0430\u043a\u043a\u0443\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442 \u0432\u00a0\u0441\u0435\u0431\u0435 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043e\u00a0\u0442\u043e\u043c, \u0441\u00a0\u043a\u0430\u043a\u043e\u0439 \u0432\u044c\u044e \u0431\u0443\u0434\u0435\u0442 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u043e\u0432\u0430\u0442\u044c \u043d\u0430\u0448\u0430 <code>button<\/code> \u043f\u0440\u0438\u00a0\u043f\u043e\u0437\u0438\u0446\u0438\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0438 \u0438 \u043a\u0430\u043a\u043e\u0439 \u0442\u0438\u043f \u0432\u0437\u0430\u0438\u043c\u043e\u0441\u0432\u044f\u0437\u0438 \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f. \u0412\u00a0\u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 center \u043d\u0430\u0448\u0435\u0439 \u043a\u043d\u043e\u043f\u043a\u0438 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0432\u0435\u043d \u0446\u0435\u043d\u0442\u0440\u0443 \u0435\u0451 <code>superView<\/code>. \u0410\u00a0\u0435\u0441\u043b\u0438 <code>superView<\/code> \u043d\u0435\u00a0\u0431\u0443\u0434\u0435\u0442 \u043d\u0430\u0439\u0434\u0435\u043d, \u0442\u043e \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u0441\u044f \u0441 <code>fatalError(\"Expected superview but found nil when attempting make constraint `equalToSuperview`.\")<\/code>. <\/p>\n<p>\u0422\u0430\u043a\u0436\u0435 \u0443 <code>ConstraintMakerEditable<\/code> \u0435\u0441\u0442\u044c \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 <code>sourceLocation<\/code>, \u0432\u00a0\u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442\u0441\u044f \u043d\u0430\u0438\u043c\u0435\u043d\u043e\u0432\u0430\u043d\u0438\u0435 \u0444\u0430\u0439\u043b\u0430 \u0438 \u043d\u043e\u043c\u0435\u0440 \u0441\u0442\u0440\u043e\u043a\u0438, \u043d\u0430\u00a0\u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043f\u0440\u043e\u0438\u0437\u043e\u0448\u0451\u043b \u0432\u044b\u0437\u043e\u0432 \u043c\u0435\u0442\u043e\u0434\u0430 <code>equalToSuperview()<\/code>, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442\u0441\u044f \u043f\u0440\u0438\u00a0\u0432\u044b\u0432\u043e\u0434\u0435 \u043e\u0448\u0438\u0431\u043e\u043a.<\/p>\n<p>4. \u041a\u043e\u043c\u043f\u0438\u043b\u044f\u0442\u043e\u0440 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u043e\u00a0\u0432\u0441\u0435\u043c \u0441\u0442\u0440\u043e\u043a\u0430\u043c \u0432\u00a0\u0437\u0430\u043c\u044b\u043a\u0430\u043d\u0438\u0438; \u0441\u00a0\u043f\u043e\u043c\u043e\u0449\u044c\u044e \u0446\u0438\u043a\u043b\u0430 <code>for<\/code> \u043f\u0435\u0440\u0435\u0431\u0438\u0440\u0430\u044e\u0442\u0441\u044f <code>descriptions<\/code>; \u0438\u0437\u00a0\u043d\u0438\u0445 \u0434\u043e\u0441\u0442\u0430\u044e\u0442\u0441\u044f \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b <code>constraint<\/code> \u0438 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u0432\u00a0\u043c\u0430\u0441\u0441\u0438\u0432.<\/p>\n<p>5. \u0414\u043b\u044f\u00a0\u043a\u0430\u0436\u0434\u043e\u0433\u043e <code>constraint<\/code> \u0438\u0437\u00a0\u044d\u0442\u043e\u0433\u043e \u043c\u0430\u0441\u0441\u0438\u0432\u0430 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043c\u0435\u0442\u043e\u0434 <code>activateIfNeeded<\/code> \u0441\u00a0\u0444\u043b\u0430\u0433\u043e\u043c updatingExisting \u0432\u00a0\u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 <code>false<\/code>, \u0447\u0442\u043e\u00a0\u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u043a\u00a0\u0432\u044b\u0437\u043e\u0432\u0443 \u043c\u0435\u0442\u043e\u0434\u0430 <code>NSLayoutConstraint.activate<\/code> \u0434\u043b\u044f\u00a0\u0430\u043a\u0442\u0438\u0432\u0430\u0446\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f.<\/p>\n<p>\u0424\u043b\u0430\u0433 <code>updatingExisting<\/code> \u043d\u0443\u0436\u0435\u043d, \u0447\u0442\u043e\u0431\u044b \u0440\u0430\u0437\u043b\u0438\u0447\u0430\u0442\u044c \u0434\u0432\u0430 \u043c\u0435\u0442\u043e\u0434\u0430: <code>makeConstraints<\/code> \u0438 <code>updateConstraints<\/code>. \u041f\u0435\u0440\u0432\u044b\u0439 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 \u0441\u043f\u0438\u0441\u043e\u043a \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u00ab\u0441 \u043d\u0443\u043b\u044f\u00bb, \u0432\u0442\u043e\u0440\u043e\u0439 \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043e\u0431\u043d\u043e\u0432\u0438\u0442\u044c \u0443\u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u044b\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f. \u041f\u0440\u0438\u043c\u0435\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u043e, \u0447\u0442\u043e\u00a0\u043f\u0440\u0438\u00a0\u0432\u044b\u0437\u043e\u0432\u0435 \u0442\u0440\u0435\u0442\u044c\u0435\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 (<code>remakeConstraints<\/code>) \u0441\u043f\u0435\u0440\u0432\u0430 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f <code>removeConstraints<\/code>, \u0432\u00a0\u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0434\u043b\u044f\u00a0\u0432\u0441\u0435\u0445 constraints \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043c\u0435\u0442\u043e\u0434 <code>deactivateIfNeeded<\/code> (<code>NSLayoutConstraint.deactivate(_:)<\/code>), \u043a\u0430\u0436\u0434\u043e\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u0443\u0434\u0430\u043b\u044f\u0435\u0442\u0441\u044f \u0438\u0437\u00a0\u043c\u0430\u0441\u0441\u0438\u0432\u0430 <code>constraints<\/code>, \u0430\u00a0\u0443\u0436\u0435 \u043f\u043e\u0442\u043e\u043c \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f <code>makeConstraints<\/code>.<\/p>\n<p>\u041f\u0440\u0438\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f (<code>updateConstraints<\/code>) \u0444\u043b\u0430\u0433 <code>updatingExisting<\/code> \u0432\u00a0\u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 <code>true<\/code> \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u0441\u0431\u043e\u0440 \u0432\u0441\u0435\u0445 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0438\u0445 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 <code>layoutConstraints<\/code> \u0434\u043b\u044f\u00a0\u0432\u044c\u044e \u0432\u00a0\u043c\u0430\u0441\u0441\u0438\u0432, \u043f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u0432\u00a0\u0446\u0438\u043a\u043b\u0435 \u0438\u0434\u0451\u0442 \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u0435 \u043a\u00a0\u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u0443 <code>LayoutConstraint<\/code>. \u0415\u0441\u043b\u0438 \u0442\u0430\u043a\u043e\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0432\u00a0\u043c\u0430\u0441\u0441\u0438\u0432\u0435, \u0442\u043e \u043e\u043d\u043e \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u0435\u0442\u0441\u044f, \u0435\u0441\u043b\u0438 \u043d\u0435\u0442\u00a0\u2014 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f <code>fatalError(\"Updated constraint could not find existing matching constraint to update: \\(layoutConstraint)\")<\/code>.<\/p>\n<p>\u0415\u0441\u0442\u044c\u00a0\u043b\u0438 \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u0432\u00a0\u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439? \u0415\u0441\u043b\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u044e\u0449\u0438\u0439 \u0430\u0442\u0440\u0438\u0431\u0443\u0442 center \u0432\u043c\u0435\u0441\u0442\u043e <code>centerX<\/code> \u0438 <code>centerY<\/code>, \u0442\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u044b\u0445 \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0432\u0441\u0435\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0434\u043b\u044f\u00a0\u043f\u043e\u0441\u0442\u0440\u043e\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u0443\u043c\u0435\u043d\u044c\u0448\u0438\u0442\u0441\u044f, \u0447\u0442\u043e\u00a0\u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0442 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u043f\u043e\u0442\u0440\u0430\u0442\u0438\u0442\u044c \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430\u00a0\u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0434\u0440\u0443\u0433\u0438\u0445 \u0437\u0430\u0434\u0430\u0447.<\/p>\n<h3>\u041e\u0448\u0438\u0431\u043a\u0438 \u043f\u0440\u0438 \u0432\u044b\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/h3>\n<p><a class=\"anchor\" name=\"UIProblems\" id=\"UIProblems\"><\/a><\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0442\u0435\u043f\u0435\u0440\u044c \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u0442\u044c\u0441\u044f, \u043e\u0442\u043a\u0443\u0434\u0430 \u043c\u043e\u0433\u0443\u0442 \u0432\u0437\u044f\u0442\u044c\u0441\u044f \u0442\u0435 \u0441\u0430\u043c\u044b\u0435 \u043e\u0448\u0438\u0431\u043a\u0438 \u0432\u00a0\u043a\u043e\u043d\u0441\u043e\u043b\u0438\u00a0\u2014 \u0447\u0442\u043e\u00a0\u043c\u043e\u0436\u0435\u0442 \u043f\u043e\u0439\u0442\u0438 \u043d\u0435\u00a0\u0442\u0430\u043a \u043f\u0440\u0438\u00a0\u0432\u044b\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u0438\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439. \u0422\u0443\u0442 \u0443\u00a0\u043c\u0435\u043d\u044f \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0441\u044f \u0441\u043f\u0438\u0441\u043e\u043a \u0438\u0437 6\u00a0\u043b\u043e\u0432\u0443\u0448\u0435\u043a, \u0443\u0433\u043e\u0434\u0438\u0442\u044c \u0432\u00a0\u043a\u043e\u0442\u043e\u0440\u044b\u0435, \u0443\u0432\u044b, \u043f\u0440\u043e\u0449\u0435, \u0447\u0435\u043c \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c\u00a0\u0431\u044b.<\/p>\n<h4>\u041b\u043e\u0432\u0443\u0448\u043a\u0430 1: \u043d\u0435 \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u0432\u0441\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f<\/h4>\n<p>\u041f\u043e\u00a0\u043c\u043e\u0435\u043c\u0443 \u043e\u043f\u044b\u0442\u0443 \u0441\u043f\u0438\u0441\u043e\u043a \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u0437\u0430\u0447\u0430\u0441\u0442\u0443\u044e \u0441\u0432\u043e\u0434\u0438\u0442\u0441\u044f \u043a\u00a0\u0442\u0430\u043a\u043e\u043c\u0443:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {   $0.center.equalToSuperview() }<\/code><\/pre>\n<p>\u0421\u043f\u0438\u0441\u043e\u043a \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439 \u043d\u0435\u00a0\u043f\u043e\u043b\u043d\u044b\u0439\u00a0\u2014 \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u0430\u044f \u043a\u043d\u043e\u043f\u043a\u0430 \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0439\u0442\u0438 \u0437\u0430\u00a0\u043f\u0440\u0435\u0434\u0435\u043b\u044b \u0441\u0432\u043e\u0435\u0433\u043e <code>superView<\/code> \u0438 \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u043d\u0435\u00a0\u0441\u043a\u0430\u0436\u0435\u0442, \u0447\u0442\u043e\u00a0\u0447\u0442\u043e\u2011\u0442\u043e \u043f\u043e\u0448\u043b\u043e \u043d\u0435\u00a0\u0442\u0430\u043a (\u0438 \u0434\u0430\u0436\u0435 \u043e\u0448\u0438\u0431\u043e\u043a Layout \u043d\u0435\u00a0\u0431\u0443\u0434\u0435\u0442).<\/p>\n<figure class=\"full-width\"><figcaption>\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0434\u043e \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/figcaption><\/figure>\n<p><strong>\u0420\u0435\u0448\u0435\u043d\u0438\u0435<\/strong>: \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043f\u043e \u043e\u0434\u043d\u043e\u043c\u0443 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044e \u043f\u043e \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u0438 \u0438 \u043f\u043e \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u0438:<\/p>\n<pre><code class=\"swift\">button.snp.makeConstraints {   $0.center.equalToSuperview()   $0.top.left.greaterThanOrEqualToSuperview() }<\/code><\/pre>\n<figure class=\"full-width\"><figcaption>\u041a\u043d\u043e\u043f\u043a\u0430 \u0441 \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u0438 \u043a\u043d\u043e\u043f\u043a\u0430 \u0441 \u0434\u043b\u0438\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c \u043f\u043e\u0441\u043b\u0435 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u0438\u044f \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439<\/figcaption><\/figure>\n<p>\u0412\u00a0\u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043d\u0430\u043c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0443\u043a\u0430\u0437\u0430\u0442\u044c \u043f\u043e\u00a0\u043e\u0434\u043d\u043e\u043c\u0443 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044e \u0434\u043b\u044f\u00a0\u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0437\u00a0\u043e\u0441\u0435\u0439, \u0442\u0430\u043a \u043a\u0430\u043a\u00a0\u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0446\u0435\u043d\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0435\u043b\u044c\u043d\u043e <code>superView<\/code>.<\/p>\n<h4>\u041b\u043e\u0432\u0443\u0448\u043a\u0430 2: \u043d\u0435<\/h><\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-346119","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/346119","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=346119"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/346119\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=346119"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=346119"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=346119"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}