How to use autolayout to scale view for all screen sizes?

前端 未结 2 1530
情书的邮戳
情书的邮戳 2021-01-06 19:09

The main navigation view of my app uses UIButtons with background images. I\'m using autolayout in IB to lay out the view.

I want the view to look the same (or simil

相关标签:
2条回答
  • 2021-01-06 19:20

    I've done some tinkering and I believe I've found a solution. I will demonstrate how to do it for the two larger squares roughly in the middle of your view.

    Here is a reference image:

    enter image description here

    First, you need to create a container (my blue view) that spans the entire width of the superview, and has a height the same or larger than your inner squares (orange).
    This view needs the following constraints: Align Center X to Superview, Align Center Y to Superview (OR constraints to give it the Y position you desire), Height Equals: [square height], Trailing Space to Superview, Leading Space to Superview.

    The inner orange squares must be placed inside the container, and must be given the following constraints: Align Center X to Superview, Leading Space to Superview (value = space between square and edge of superview), Trailing Space to [other view] (value = space between squares). Select the two squares together, and add Aspect Ratio, Equal Width and Equal Height constraints.
    The items in bold depend on which square you're selecting. The left one should have leading space to superview and trailing space to the other view, and the right one should have these constraints swapped.

    This should give you your desired effect with autolayout.

    0 讨论(0)
  • 2021-01-06 19:27

    A little late to the party but I guess this will help someone in the future. Here is what I think is a better way to do it. I will write the steps I followed to achieve the desired result.

    1 - Add both the squares in the view controller as below.

    2 - Now select the first cube, and select the Pin menu from the bottom of the screen. Add the top and left constraints.

    3 - Now select the second cube, the one on the right and add right and top constraints to it from the Pin menu.

    4 - Now select the first cube, and cntrl-drag from inside of the cube to the view controller. Now select 'Equal Widths' from the menu. Confused huh ? Hold on.

    5 - Now double click on the 'Equal Widths' constraint line and a menu will pop up. In the 'Multiplier' field change the value to 0.4

    6 - Repeat step 4 and 5 for the right cube.

    7 - This is how the result will look like in different sizes of iPhone. (The first one is a 4-inch device, the second is a 4.7-inch device and the third is a 3.5-inch device). P.S: The bottoms are cropped because the screenshot is from preview :)

    UPDATE (16/01/2018)

    In step 4, intead of selecting 'Equals Width', select 'Aspect Ratio'. Omit step 5 after this.

    0 讨论(0)
提交回复
热议问题