Wayback Machinekoobas.hobune.stream
May JUN Jul
Previous capture 14 Next capture
2021 2022 2023
2 captures
12 Jun 22 - 14 Jun 22
sparklines
Close Help
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
  • Asset Store
  • Get Unity

UNITY ACCOUNT

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account
  • Blog
  • Forums
  • Answers
  • Evangelists
  • User Groups
  • Beta Program
  • Advisory Panel

Navigation

  • Home
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
    • Blog
    • Forums
    • Answers
    • Evangelists
    • User Groups
    • Beta Program
    • Advisory Panel

Unity account

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account

Language

  • Chinese
  • Spanish
  • Japanese
  • Korean
  • Portuguese
  • Ask a question
  • Spaces
    • Default
    • Help Room
    • META
    • Moderators
    • Topics
    • Questions
    • Users
    • Badges
  • Home /
avatar image
0
Question by Thephil2988 · Feb 25, 2018 at 10:55 AM · screenpositioningboxscreen.widthscreen.height

Screen height and width confusion

I dont really get why this doesn't work:

 GUI.Box(new Rect(Screen.height/2, Screen.width/2, 100, 100),"Box in the middle");

The way I understand this, the code should place a 100*100 box with its left top side directly in the middle of the game. What i get is a box that is placed almost in the bottom and a bit to the left. And if i maximize on play the box is not even there (guessing its outside the camera area).

Am i missing something big, or is there anotother way to get a position by using Screen.height and Screen.Width? i want my box to scale to different screens, which is why i am doing it this way

Comment
Add comment
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users

1 Reply

· Add your reply
  • Sort: 
avatar image
2
Best Answer

Answer by Xarbrough · Feb 25, 2018 at 02:05 PM

You need to flip height and width like this and also offset the position by half the width (because the box pivot is at a corner, not the center):

 using UnityEngine;
 
 public class Test : MonoBehaviour
 {
     void OnGUI()
     {
         Rect rect = new Rect(Screen.width / 2f, Screen.height / 2f, 120f, 60f);
         rect.x -= rect.width / 2f;
         rect.y -= rect.height / 2f;
         GUI.Box(rect, "Box in the middle");
     }
 }
 

Maybe you can think of it like this as well:

 Vector2 size = new Vector2(120f, 60f);
 
 Vector2 position = new Vector2(
     x: Screen.width / 2f - size.x / 2f,
     y: Screen.height / 2f - size.y / 2f);
 
 GUI.Box(new Rect(position, size), "Box in the middle");

Also be aware that the this is the legacy GUI system and is replaced by the new Unity UI system. The new system makes layouting much easier because it uses anchors and layout groups which do the work for you. It also has better performance than the legacy immediate mode GUI.

Scaling in the legacy GUI system was more of a hassle. If you want your box to stay the same size across multiple resolutions, you either have to calculate the position and size of every element manually by factoring in the screen size or edit the GUI.matrix like this:

 Vector2 referenceResolution = new Vector2(1920f, 1080f);
 Vector3 scaling = new Vector3(
     x: Screen.width / referenceResolution.x,
     y: Screen.height / referenceResolution.y,
     z: 1f);
 GUI.matrix = Matrix4x4.TRS(Vector3.zero, Quaternion.identity, scaling);
 
 Vector2 size = new Vector2(1920f - 50f, 260f);
 Vector2 position = new Vector2(Screen.width / 2f, Screen.height / 2f);
 position -= size / 2f;
 
 GUIStyle style = new GUIStyle(GUI.skin.box);
 style.fontSize = 30;
 GUI.Box(new Rect(position, size), "Box in the middle", style);

This will ensure that on 16:9 screens, the box fills the screen. But, you can also see that it's a difficult topic, because its still strongly connected to your reference resolution, so it doesn't adapt between portrait and landscape resolution, etc. All of these problems are solved by the new UI system, which was introduced with Unity 4.6, though.

Comment
Add comment · Show 1 · Share
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users
avatar image Bunny83 · Feb 25, 2018 at 04:57 PM 1
Share

Note that the Rect now has a center property which can be set as well. So you can simply do

 Rect rect = new Rect(0 , 0, 120f, 60f);
 rect.center = new Vector2(Screen.width / 2f, Screen.height / 2f);
 GUI.Box(rect, "Box in the middle");



Your answer

Hint: You can notify a user about this post by typing @username

Up to 2 attachments (including images) can be used with a maximum of 524.3 kB each and 1.0 MB total.

Follow this Question

Answers Answers and Comments

77 People are following this question.

avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image

Related Questions

Screen.width and Screen.height sometimes flipped for Android 1 Answer

When are Screen.width and Screen.height updated after changing the Screen.orientation value? 0 Answers

Positioning across various resolutions 0 Answers

Unity 3.5.7 Android Screen returns the wrong value? 0 Answers

Make area adapt to screen size 1 Answer


Enterprise
Social Q&A

Social
Subscribe on YouTube social-youtube Follow on LinkedIn social-linkedin Follow on Twitter social-twitter Follow on Facebook social-facebook Follow on Instagram social-instagram

Footer

  • Purchase
    • Products
    • Subscription
    • Asset Store
    • Unity Gear
    • Resellers
  • Education
    • Students
    • Educators
    • Certification
    • Learn
    • Center of Excellence
  • Download
    • Unity
    • Beta Program
  • Unity Labs
    • Labs
    • Publications
  • Resources
    • Learn platform
    • Community
    • Documentation
    • Unity QA
    • FAQ
    • Services Status
    • Connect
  • About Unity
    • About Us
    • Blog
    • Events
    • Careers
    • Contact
    • Press
    • Partners
    • Affiliates
    • Security
Copyright © 2020 Unity Technologies
  • Legal
  • Privacy Policy
  • Cookies
  • Do Not Sell My Personal Information
  • Cookies Settings
"Unity", Unity logos, and other Unity trademarks are trademarks or registered trademarks of Unity Technologies or its affiliates in the U.S. and elsewhere (more info here). Other names or brands are trademarks of their respective owners.
  • Anonymous
  • Sign in
  • Create
  • Ask a question
  • Spaces
  • Default
  • Help Room
  • META
  • Moderators
  • Explore
  • Topics
  • Questions
  • Users
  • Badges