[BotW] Fix centered HUD mode

Forgot how I made my original formula for the edge HUD, but now I finally understand MATH!
This commit is contained in:
Crementif 2022-01-21 18:58:42 +01:00
parent 4cdffcaef2
commit 84fb724c9e
No known key found for this signature in database
GPG key ID: 12BB8BD3EA30651E

View file

@ -86,7 +86,7 @@ bne checkScreenNames
lis r11, copySubPanelStringLen@ha
lwz r11, copySubPanelStringLen@l(r11)
lis r12, copySubPanelString@ha
addi r12, r12, copySubPanelString@l
addi r12, r12, copySubPanelString@l
copySubPanelLoop:
lbzx r10, r5, r11
@ -607,7 +607,7 @@ b exitScale
const_SensorsOffset:
.float 392.0
scaleSensorMeterPanes:
scaleSoundMeterPanes:
addi r5, r31, 0x80
lis r10, const_SensorsOffset@ha
lfs f12, const_SensorsOffset@l(r10)
@ -616,7 +616,7 @@ addi r10, r10, str_N_InOut_00@l
bla _compareString
beq scalePaneAndKeepCustomPosIf
b exitScale
scaleSoundMeterPanes:
scaleSensorMeterPanes:
addi r5, r31, 0x80
lis r10, const_SensorsOffset@ha
lfs f12, const_SensorsOffset@l(r10)
@ -635,7 +635,7 @@ bla _compareString
beq scalePaneAndKeepCustomPosIf
b exitScale
const_TimeOffset:
.float 342*0.85
.float (($ultrawideHUDMode == 1) * (342*0.85)) + (($ultrawideHUDMode == 2)*(342*(1/0.85)))
scaleMainScreenTimePanes:
addi r5, r31, 0x80
lis r10, const_TimeOffset@ha
@ -2172,7 +2172,7 @@ b exitScale
; Generic methods used to scale a specific pane type
scaleRootToCenter:
addi r5, r31, 0x80 ; address to first character of the pane name that's getting loaded
addi r5, r31, 0x80 ; address to first character of the pane name that's getting loaded
lis r10, str_RootPane@ha
addi r10, r10, str_RootPane@l
bla _compareString
@ -2261,13 +2261,13 @@ b exitScale
scalePaneAndSize:
lis r10, const_AspectRatio@ha
lfs f9, const_AspectRatio@l(r10)
lfs f9, const_AspectRatio@l(r10)
lfs f0, 0x0(r27)
fmuls f0, f0, f9
stfs f0, 0x0(r27)
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2275,7 +2275,7 @@ b exitScale
scaleOnlySize:
lis r10, const_AspectRatio@ha
lfs f9, const_AspectRatio@l(r10)
lfs f9, const_AspectRatio@l(r10)
lfs f0, 0x0(r27)
fmuls f0, f0, f9
stfs f0, 0x0(r27)
@ -2283,7 +2283,7 @@ b exitScale
scaleOnlySizeReverse:
lis r10, const_ReverseAspectRatio@ha
lfs f9, const_ReverseAspectRatio@l(r10)
lfs f9, const_ReverseAspectRatio@l(r10)
lfs f0, 0x0(r27)
fmuls f0, f0, f9
stfs f0, 0x0(r27)
@ -2292,7 +2292,7 @@ b exitScale
; Scales pane to left side
scalePaneToLeftSide:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2329,7 +2329,7 @@ b exitScale
; Scales pane to right side
scalePaneToRightSide:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2359,7 +2359,7 @@ b exitScale
scalePaneToRightSideAlt:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2373,7 +2373,7 @@ b exitScale
scalePaneReverseToLeft:
lis r10, const_ReverseAspectRatio@ha
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2387,7 +2387,7 @@ b exitScale
scalePaneReverseToRight:
lis r10, const_ReverseAspectRatio@ha
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2402,7 +2402,7 @@ b exitScale
; Divides the width of this element with the change in aspect ratio
scalePaneNormal:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2410,13 +2410,13 @@ b exitScale
scalePaneAndPos:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x1C(r31)
fmuls f0, f0, f9
stfs f0, 0x1C(r31)
@ -2424,7 +2424,7 @@ b exitScale
scaleOnlyPos:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x1C(r31)
fmuls f0, f0, f9
stfs f0, 0x1C(r31)
@ -2436,6 +2436,12 @@ const_640:
const_1:
.float 1.0
scalePaneAndKeepPosIf:
li r10, $ultrawideHUDMode
cmpwi r10, 1
beq scalePaneAndKeepPos
bne scalePaneAndPos
scalePaneAndKeepPos:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
@ -2469,44 +2475,12 @@ fsubs f0, f11, f0
stfs f0, 0x1C(r31)
b exitScale
scalePaneAndKeepPosIf:
li r10, $ultrawideHUDMode
cmpwi r10, 1
beq scalePaneAndKeepPos
bne scalePaneAndPos
moveKeepPos:
lis r10, const_0@ha
lfs f11, const_0@l(r10)
lfs f9, 0x1C(r31)
fcmpu f9, f11
lis r10, const_640@ha
lfs f0, const_640@l(r10)
lfs f9, 0x1C(r31)
bge .+0x08
fsubs f9, f11, f9
fsubs f0, f0, f9
lis r10, const_1@ha
lfs f13, const_1@l(r10)
lis r10, const_AspectRatio@ha
lfs f9, const_AspectRatio@l(r10)
fsubs f13, f13, f9
fmuls f0, f0, f13
lfs f9, 0x1C(r31)
bge .+0x08
fsubs f9, f11, f9
fadds f0, f9, f0
bge .+0x08
fsubs f0, f11, f0
stfs f0, 0x1C(r31)
b exitScale
; Pass custom pos as f12
scalePaneAndKeepCustomPosIf:
li r10, $ultrawideHUDMode
cmpwi r10, 1
beq scalePaneAndKeepCustomPos
bne scalePaneAndCenterCustomPos
bne scalePaneAndCustomPos
scalePaneAndKeepCustomPos:
lis r10, const_AspectRatio@ha
@ -2515,6 +2489,7 @@ lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
; [XPositionOfPane] + ((1280/2 - [XPositionOfPane]) * (1-[AspectRatio])))
lis r10, const_0@ha
lfs f11, const_0@l(r10)
lfs f9, 0x1C(r31)
@ -2544,15 +2519,48 @@ fsubs f0, f0, f12
stfs f0, 0x1C(r31)
b exitScale
; todo: currently broken for left-sided elements
scalePaneAndCenterCustomPos:
# ; [XPositionOfPane] + ((1280/2 - [XPositionOfPane]) * (1-[AspectRatio])))
# lis r10, const_640@ha
# lfs f0, const_640@l(r10) ; (1280/2)
# lfs f9, 0x1C(r31)
# fadds f9, f9, f12 ; Create XPositionOfPane (add position of current pane + custom position of parent pane)
# fsubs f0, f0, f9 ; (1280/2) - XPositionOfPane
# lis r10, const_1@ha
# lfs f13, const_1@l(r10)
# lis r10, const_AspectRatio@ha
# lfs f9, const_AspectRatio@l(r10)
# fsubs f13, f13, f9 ; (1-[AspectRatio])
# fmuls f0, f0, f13 ; ((1280/2) - XPositionOfPane) * (1-[AspectRatio])
# lfs f9, 0x1C(r31)
# fadds f9, f9, f12 ; [XPositionOfPane]
# fadds f0, f9, f0 ; [XPositionOfPane] + ((1280/2 - [XPositionOfPane]) * (1-[AspectRatio])))
# fsubs f0, f0, f12
; Explanation: The current position is 3x as big as it should be (let's take 3x at 48:9), so to correct that you scale it back by
; XPositionOfPane*(1-AspectRatio)
scalePaneAndCustomPos:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
; [XPositionOfPane] + ((1280/2 - [XPositionOfPane]) * (1-[AspectRatio])))
lis r10, const_1@ha
lfs f9, const_1@l(r10)
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
fsubs f0, f9, f0
lfs f9, 0x1C(r31)
fsubs f9, f9, f12
fmuls f0, f9, f0
stfs f0, 0x1C(r31)
b exitScale
moveKeepPos:
lis r10, const_0@ha
lfs f11, const_0@l(r10)
lfs f9, 0x1C(r31)
@ -2576,26 +2584,28 @@ fadds f0, f9, f0
bge .+0x08
fsubs f0, f11, f0
stfs f0, 0x1C(r31)
lis r10, const_640@ha
lfs f11, const_640@l(r10)
fsubs f0, f0, f11
stfs f0, 0x1C(r31)
b exitScale
movePaneToCustomSize:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
; Pass the scale in f0 and position in f12
scalePaneWithCustomPosAndScale:
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
lfs f9, 0x1C(r31)
fsubs f0, f9, f12
stfs f12, 0x1C(r31)
b exitScale
movePaneToCustomPos:
lfs f9, 0x1C(r31)
fsubs f0, f9, f12
stfs f12, 0x1C(r31)
b exitScale
scalePaneHalf:
lis r10, const_AspectRatioHalf@ha
lfs f0, const_AspectRatioHalf@l(r10)
lfs f0, const_AspectRatioHalf@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2603,7 +2613,7 @@ b exitScale
scalePaneReverse:
lis r10, const_ReverseAspectRatio@ha
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2611,13 +2621,13 @@ b exitScale
scalePaneAndPosReverse:
lis r10, const_ReverseAspectRatio@ha
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
lis r10, const_ReverseAspectRatio@ha
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f9, 0x1C(r31)
fmuls f0, f0, f9
stfs f0, 0x1C(r31)
@ -2625,7 +2635,7 @@ b exitScale
scalePaneReverse2x:
lis r10, const_ReverseAspectRatio2x@ha
lfs f0, const_ReverseAspectRatio2x@l(r10)
lfs f0, const_ReverseAspectRatio2x@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2633,7 +2643,7 @@ b exitScale
scalePaneOnYScale:
lis r10, const_ReverseAspectRatio@ha
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f0, const_ReverseAspectRatio@l(r10)
lfs f9, 0x38(r31)
fmuls f0, f0, f9
stfs f0, 0x38(r31)
@ -2641,7 +2651,7 @@ b exitScale
scalePaneOnYScaleReverse:
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x38(r31)
fmuls f0, f0, f9
stfs f0, 0x38(r31)
@ -2649,7 +2659,7 @@ b exitScale
scaleReversePaneToRightSide:
lis r10, const_ReverseAspectRatio2x@ha
lfs f0, const_ReverseAspectRatio2x@l(r10)
lfs f0, const_ReverseAspectRatio2x@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2681,7 +2691,7 @@ mapXPositionAddr:
scaleMapAndStore:
; scale pane and move to right on initialization
lis r10, const_AspectRatio@ha
lfs f0, const_AspectRatio@l(r10)
lfs f0, const_AspectRatio@l(r10)
lfs f9, 0x34(r31)
fmuls f0, f0, f9
stfs f0, 0x34(r31)
@ -2810,7 +2820,7 @@ _createNewScreenHook:
lis r11, copyScreenStringLen@ha
lwz r11, copyScreenStringLen@l(r11)
lis r12, copyScreenString@ha
addi r12, r12, copyScreenString@l
addi r12, r12, copyScreenString@l
copyNameLoop:
lbzx r10, r24, r11
@ -2823,7 +2833,7 @@ bne copyNameLoop
lis r11, copySubPanelStringLen@ha
lwz r11, copySubPanelStringLen@l(r11)
lis r12, copySubPanelString@ha
addi r12, r12, copySubPanelString@l
addi r12, r12, copySubPanelString@l
eraseSubPanelLoop:
li r10, 0