Skip to content

Commit

Permalink
Better explaining how mirroring works.
Browse files Browse the repository at this point in the history
I wrote everything I wish was written when I tried to make an
infinite scrolling background, addressing every point of every
mistake I made.
  • Loading branch information
lvella committed Sep 30, 2023
1 parent 6758a7f commit 996714c
Showing 1 changed file with 4 additions and 3 deletions.
7 changes: 4 additions & 3 deletions doc/classes/ParallaxLayer.xml
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,10 @@
</tutorials>
<members>
<member name="motion_mirroring" type="Vector2" setter="set_mirroring" getter="get_mirroring" default="Vector2(0, 0)">
The ParallaxLayer's [Texture2D] repeating. Useful for creating an infinite scrolling background. If an axis is set to [code]0[/code], the [Texture2D] will not be repeated.
If the length of the viewport axis is bigger than twice the repeated axis size, it will not repeat infinitely, as the parallax layer only draws 2 instances of the texture at any given time.
[b]Note:[/b] Despite its name, the texture will not be mirrored, it will simply be repeated.
The interval, in pixel units, at which the [ParallaxLayer] is drawn repeatedly. Useful for creating an infinite scrolling background. If an axis is set to [code]0[/code], the [ParallaxLayer] will be drawn only once along that direction.
Notice that if you want the repeatition to pixel-perfect match a [Texture2D] displayed by a child node, you should account for any scale applied to the texture when defining this interval. E.g., if you use a child [Sprite2D] scaled to [code]0.5[\code] to display a 600x600 texture, and want this sprite to be repeated continuously horizontally, you should set the mirroring to [code]Vector2(300, 0)[\code].
If the length of the viewport axis is bigger than twice the repeated axis size, it will not repeat infinitely, as the parallax layer only draws 2 instances of the texture at any given time. The visibility window is calculated from the parent's [ParallaxBackground] position, not the layer's own position. So, if you use mirroring, [b]do not[\b] change the [ParallaxLayer] position relative to its parent. Instead, if you need to adjust the background's position, set the [code]offset[\code] property in the parent [ParallaxBackground].
[b]Note:[/b] Despite its name, the drawing will not be mirrored, it will simply be repeated.
</member>
<member name="motion_offset" type="Vector2" setter="set_motion_offset" getter="get_motion_offset" default="Vector2(0, 0)">
The ParallaxLayer's offset relative to the parent ParallaxBackground's [member ParallaxBackground.scroll_offset].
Expand Down

0 comments on commit 996714c

Please sign in to comment.