How Do Computers Display 3D on a 2D Screen? (Perspective Projection)

Поділитися
Вставка
  • Опубліковано 22 січ 2025

КОМЕНТАРІ • 69

  • @justplay2508
    @justplay2508 Рік тому +16

    Your explanation is so clear and concise that I had an "ahah" moment where every piece just fell into place and dots started connecting

  • @rddd89
    @rddd89 22 дні тому

    This is great because it does *not* include the matrix math, just the bare fundamentals of going from world space to screen space. Good stuff!

  • @lodgechant
    @lodgechant 10 місяців тому +3

    Thanks for this wonderful introduction. I failed maths at school and wasn't shown the value of trig when I was a kid. You've blown my mind!

  • @lukaknight9589
    @lukaknight9589 2 роки тому +25

    thank you so much, I'm so glad I found out this video. I've been seeking information about projections for a few days and couldn't find any information that wasn't irrelevant or too advanced, but, finally, I found your video and now I understand everything and was able to make my own 3d projection in js.

    • @w花b
      @w花b 2 роки тому +5

      Right, I've finally found something that's properly explained.

  • @glace848
    @glace848 4 місяці тому

    bro all the other explanations i found were just kinda talking about how 1/tan(\theta/2) is just a reasonable choice because like "it scales the things from world space appropriatly". thx for actually explaining the real math behind it

  • @STBrian159
    @STBrian159 8 місяців тому

    I really loved the video. I come from another video that began to explain somewhat more advanced things and I didn't understand anything. Maybe this is a little simpler but it is really useful when you are new in this area. Keep making content like this, intuitive and easy to understand!!

  • @shpleemcgert
    @shpleemcgert 7 місяців тому

    This is an awesome explanation. You have a gift for teaching!

  • @fdanavarro
    @fdanavarro Рік тому

    Thanks for taking the time to explain it in such a good way

  • @iwaduarte
    @iwaduarte Рік тому +3

    Exactly like @LukaB Knight posted. Your content is straightforward and goes in-depth about the perspective subject. Most content are math-heavy based or lazy representations. Especially content from universities and professors. They assume you know their derived thoughts in powerpoint presentations or even worse, they start with a really good explanation in the introduction just to come up with crazy things once things get real.
    Keep up the excellent work. Keep it simple (KISS) should be a rule that everyone that produces content should strictly follow. Congrats

  • @plasthree
    @plasthree Рік тому

    This is the best I've seen about this topic. Thank you so so much to explained this. ❤❤❤

  • @Extner4
    @Extner4 Рік тому

    THIS WAS SO USEFUL! I was trying to fix a bug and I just could't find it. When I watched this video I realized my core projection was wrong! And it works now. tysm!

  • @laurin__
    @laurin__ Рік тому +1

    Really cool video, thx!!
    This was soo helpful and first video on this subject i didnt find overwhelming as a medium iq guy, thanks for the simple and concise explanation

  • @blaisofotso3439
    @blaisofotso3439 Рік тому

    That was so well done, Kudos.
    Wish i could see more of these concepts explained.
    Warm regards

  • @imfaded3105
    @imfaded3105 2 роки тому +3

    Great explanation

  • @kin_1997
    @kin_1997 7 місяців тому +1

    Amazing video, thank you for helping the topic click,

  • @lesablier6744
    @lesablier6744 2 роки тому +2

    Thank you very much for your explainations !

  • @vimy-hh8uz
    @vimy-hh8uz 2 місяці тому

    Amazing explanation!

  • @original16gstudio80
    @original16gstudio80 11 місяців тому

    Finally, btw love ur drawing ❤

  • @MusicTee
    @MusicTee 7 місяців тому

    very informative video, i just made my first 3d renderer using this

  • @dipokdipu-h9j
    @dipokdipu-h9j 11 місяців тому

    Such a good explanation....thanks

  • @Sleir_
    @Sleir_ 2 роки тому +1

    this video was well made, thank you

  • @frycomfort4002
    @frycomfort4002 2 роки тому +1

    Clear and Amazing

  • @giveaway4002
    @giveaway4002 2 роки тому +1

    this is awesome!

  • @carstenmohler629
    @carstenmohler629 6 місяців тому +2

    I know a Danish dialect when I hear one. No Dane can avoid the Danglish. Thanks for the video, my fellow LEGO-eating windmill-hugger.

  • @bestcodepractice7898
    @bestcodepractice7898 Рік тому

    Bro you are freaking amazing ❤❤❤

  • @dennisrajan8020
    @dennisrajan8020 9 місяців тому

    This is Amazing! Thanks a lot!

  • @StefLubs-qs5lm
    @StefLubs-qs5lm 2 місяці тому

    Amazing!

  • @mrshodz
    @mrshodz Рік тому

    Nice explanation.

  • @nikolastamenkovic7069
    @nikolastamenkovic7069 Рік тому +1

    At some points of the video, I thought that you were dumbing down the concept hardly, and that made me a bit impatient.. but overall - really great stuff!

  • @dijik123
    @dijik123 Рік тому +1

    Ur not carl the person ur carl the legend

  • @jbragg33
    @jbragg33 6 місяців тому

    Amazing, thanks

  • @sidtronics
    @sidtronics 2 роки тому

    That is so awesome!

  • @edht2
    @edht2 25 днів тому

    OMG Thank you so much!!!

  • @culan_SCP
    @culan_SCP 10 місяців тому

    just a question? what is the dot symbol in the calculations at 23:15?

    • @kn-ki4637
      @kn-ki4637 9 місяців тому +2

      you mean the multiplication symbol? it means z times tan(a/2).

    • @AndrewX981
      @AndrewX981 6 місяців тому +2

      It's just mutiplication. We use it this way since there is also an x variable that may seem as multiplication.

    • @Inv1xxity
      @Inv1xxity Місяць тому

      @@kn-ki4637thanks!

  • @theengineer9910
    @theengineer9910 Рік тому

    Thank you !

  • @itsiashu
    @itsiashu Місяць тому

    Great explanation and cool presentation.
    Question: shouldn't method name be like transform3Dto2D() or get2Dfrom3D()?

  • @MostafaAshraf-iu4yq
    @MostafaAshraf-iu4yq 2 роки тому

    Your a legend

  • @orangomango
    @orangomango 2 роки тому

    AMAZING

  • @kemuus
    @kemuus 3 місяці тому

    Thx a lot

  • @turner7777
    @turner7777 Рік тому

    great explenation, but wouldnt this only work if the camera never rotated? For example what if you rotate 10 degrees right (or up, depending on your perspective), then the triangles that are formed wont be right triangles so the formula wont stand and also the whole plane shifts

  • @yapianomaster
    @yapianomaster Рік тому +1

    Amazing😱 It would be nice to show that there is a Zp coordinate too, however its value is always n, and because of that, we see the 3d object on the "2d plane" which its actually 3d, but flat hh, and because of that, the Zp can be ignored, for 2d porpuses.

    • @Bunny99s
      @Bunny99s Рік тому

      Actually when doing proper 3d rendering with OpenGL or DirectX we use a matrix to do all those transformations at once. We actually have a z value, but that's not just "n" but specifically claculated so it can be used to sort things in depth. Your GPU actually has a depth buffer besides the actual frame buffer which holds the color information of the pixels. The depth value is actually written into the depth buffer. That way things that were drawn first can occlude things drawn later.
      Anyways. This video ia a good introduction in the very fundamentals of 3d projection. In actual gameengines or 3d applications we use 4d homogeneous coordinates and 4x4 matrices to define any position or transformation.

  • @AnvarRaxmonov23
    @AnvarRaxmonov23 Рік тому

    Thanks

  • @jammin1336
    @jammin1336 10 місяців тому +8

    Because math

  • @Karmush21
    @Karmush21 2 роки тому +1

    Is it really true to say that the near plane and screen is the same thing?

  • @siirkire
    @siirkire 2 роки тому +1

    Cool cup

  • @melangesvolatils6506
    @melangesvolatils6506 7 місяців тому

    Cooool

  • @johnymnemonic4657
    @johnymnemonic4657 3 місяці тому

    xp=(x*d)/z yp=(y*d)/z d-distance from observer.Prespective view.

  • @andrewdunbar828
    @andrewdunbar828 2 роки тому

    You don't need trigonometry for perspective projection. You only need it for rotation. For perspective projection you just divide your X and Y each by your Z. In practice you'll want to use scaling factor and a Z offset in 3D space and X and Y offsets in screen space to normalize to the centre of the screen like you covered.
    I figured this out with a friend in the early '80s when I was 13 or 14. I didn't know most of the terminology and never learned matrices let alone all the amazing fancy stuff used these days.
    I don't understand the stuff with tan and your a variable.

    • @FlanPoirot
      @FlanPoirot Рік тому +1

      he used basic trigonometry. basically if you know 2 sides of a triangle you can know the other side by using sin, cos and tan.
      so since u want to scale down distant objects, its ratio should be the same, aka the triangle between the camera and the projection and the camera and the real distance of the object would have the same ratio. so you can know the w / h will be the same on both instances.
      so hp / wp = h / w (p standing for projection). solving for the projected height you have hp = h / w / wp which becomes hp = h / (w * wp)
      since wp is tan(2/a) (this means that the angle of the point you're projecting is half the total angle of the frustum if you look at the drawing he made you can see that this is the case) so we can just substitute wp for tan(2/a) in our equation
      hp = h / (w * tan(2/a))
      and the same can be said for width so
      wp = w / (h * tan(2/a))
      choosing an angle and using the points in the plain for your object and solving the equation, it will give you the projected coordinates for the object

    • @ellis447
      @ellis447 Рік тому

      This guys a genius!

    • @pixellino5009
      @pixellino5009 Рік тому

      Matrices are used for the calculation of the coordinates in space rather than projection.

    • @andrewdunbar828
      @andrewdunbar828 Рік тому +1

      @@pixellino5009 Matrices are used for both rotation and projection. But they don't need to be used for either. I believe the big win with matrices is that you can combine several rotations and projection all into one operation and by doing so ultimately use fewer discrete calculations. But I'm not sure. Also I believe these days quaternions are often used instead.
      Caveat: I'm bad at matrices and barely have a clue wrt quaternions, but when I was a kid in the '80s I did 3D rotation and projection on the 8-bit computers we had back then regardless.

    • @angeldude101
      @angeldude101 Рік тому +1

      Trigonometric functions aren't needed if you start out with the distance of the near plane. The tan function is only used here to derive the distance of the near plane from the viewing angle. After you have the near plane, everything else is just similar triangles.

  • @AntoineVanGeyseghem
    @AntoineVanGeyseghem Рік тому

    :O

  • @krut4rth
    @krut4rth 3 місяці тому

    good explanation but music was so annoying sorry to say but it was distracting

  • @dheerparekh1305
    @dheerparekh1305 8 місяців тому

    Good video but improve on your presentation and speech delivery

  • @monkeyrobotsinc.9875
    @monkeyrobotsinc.9875 11 місяців тому +5

    uhh cool but why did you make a whole video about perspective and then at the very end show a cube that looks 100% orthographic? LOL u serious? wow. cool. also turn up the volume on your next video.

    • @Ðogecoin
      @Ðogecoin 9 місяців тому

      you sound like a redditor

    • @celian_ds
      @celian_ds 7 місяців тому

      It does not, you can clearly see the back face is smaller.

    • @kin_1997
      @kin_1997 7 місяців тому

      The math is correct, could be just an optical illusion

    • @ColourlessGreenIdeas567
      @ColourlessGreenIdeas567 5 місяців тому

      Dude shut up

  • @culan_SCP
    @culan_SCP 10 місяців тому

    WHY DO YOU USE SO MANY LIBRARYS ITS SO CONFUSING PLZ PUT RAW HTML AND CSS AND JS 😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭😭

  • @eliseoduque3261
    @eliseoduque3261 2 роки тому +1

    amazing video , actually learned well