Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

<Bounds /> #408

Open
4 tasks done
andretchen0 opened this issue May 8, 2024 · 4 comments
Open
4 tasks done

<Bounds /> #408

andretchen0 opened this issue May 8, 2024 · 4 comments
Assignees
Labels
feature New feature or request p2-nice-to-have Not breaking anything but nice to have (priority)

Comments

@andretchen0
Copy link
Contributor

andretchen0 commented May 8, 2024

Description

As a developer using TresJS, I would like to have a component that can keep child components centered on screen, even after screen resizes.

Suggested solution

A component that works like Drei's <Bounds /> would be welcome.

Alternative

No response

Additional context

No response

Validations

@andretchen0 andretchen0 added feature New feature or request p2-nice-to-have Not breaking anything but nice to have (priority) labels May 8, 2024
@andretchen0 andretchen0 changed the title Feature: <Bounds /> <Bounds /> May 8, 2024
@schplitt
Copy link
Contributor

schplitt commented Jun 7, 2024

I would like to implement this.
I have a suggestion for how to 'improve' the behavior.
It seems that the current implementation of Drei's Bounds does not take into account, that the camera might not be directly looking at the Bounds. Thus the bounds may not fit if the margin is 1.

This can be fixed if the rendered 2d output is taken for determining the distance the camera has to be.
It is a bit more computational work, but might be worth it to always assure correct bounds.

This could then also be used to implement a more html like margin where the margin actually represents the margin from the edges of the rendered image and not an arbitrary distance modification.

What are your thoughts on this?

@andretchen0
Copy link
Contributor Author

andretchen0 commented Jun 7, 2024

Hey @JakobHock

Sure thing. You're welcome to implement <Bounds />.

This can be fixed if the rendered 2d output is taken for determining the distance the camera has to be.
It is a bit more computational work, but might be worth it to always assure correct bounds.

I think this could work, but as you mention, it's going to be more expensive computationally. Since some users will call this every frame, ideally, I think we should aim for a solution that doesn't require rendering.


Otherwise, I noticed that Cientos is missing a <Cylinder /> shape. I created an issue here.

That might be a good first issue, since it'll expose you to the other stuff that's involved in publishing a Cientos component – creating/updating a playground, writing docs/demos – without also being challenging to implement in its own right.

And I personally find the shape components super handy and would like to have another!

Let me know if that sounds good and I'll assign you so others don't duplicate your effort.

Your call though. Thanks!

@schplitt
Copy link
Contributor

schplitt commented Jun 7, 2024

Hello @andretchen0,

I will hold off on implementing <Bounds />.
I think i might have a misconception of what Drei is doing. As far as i can tell it calculates the end position once and tries to prevent the user from hijacking the camera controls. Thus the position would only be calculated once. This is also what i have implemented in my POC.
But as my react skills are somewhat poor it might have gotten the wrong idea.
Happy to discuss though!

Anyway i will take you up on your offer to start with the <Cylinder /> component. :)


Here is the type that would be returned by the useBounds composable and the props of the <Bounds /> component:

Bounds:

export type Bounds = {
	/**
	 * Indicates if the bounds animation is playing. Is `true` even if the animation is paused.
	 */
	playing: ComputedRef<boolean>
	/**
	 * Indicates if the bounds animation is paused.
	 */
	paused: ComputedRef<boolean>
	/**
	 * Indicates if the bounds animation has finished.
	 */
	finished: ComputedRef<boolean>
	/**
	 * The current progress of the animation. It is a number between 0 and 1.
	 */
	progress: ComputedRef<number>
	/**
	 * Plays the animation according to the props given to the `<Bounds />` component. Camera controls if present are disabled during the animation.
	 */
	play: () => void
	/**
	 * Pauses the animation. Does not enable camera controls.
	 */
	pause: () => void
	/**
	 * Resumes the animation.
	 */
	resume: () => void
	/**
	 * Skips the animation and sets the view immediately to the end.
	 */
	skip: () => void
	/**
	 * Stops the animation and resets the the camera to the initial position.
	 */
	reset: () => void
	/**
	 * Aborts the animation. Leaves the camera at the position at which the animation was aborted.
	 */
	abort: () => void
	/**
	 * Callback function that is called when the animation starts.
	 */
	onStart: (callback: (startPosition: Vector3, endPosition: Vector3) => {}) => void
	/**
	 * Callback function that is called when the animation ends.
	 */
	onEnd: (callback: (startPosition: Vector3, endPosition: Vector3) => {}) => void
}

Props:

export type BoundsProps = {
		immediate?: boolean
		margin?: number
		duration?: number
		interpolateFunc?: (t: number) => number
}

@andretchen0
Copy link
Contributor Author

@JakobHock ,

It's totally possible I'm misinterpreting what Drei's <Bounds /> is doing.

Good to hear about <Cylinder />. I've assigned it to myself for now, just to let others know that someone's working on it. If you want to comment over there, I should be able to assign it to you.

Cheers!

@andretchen0 andretchen0 self-assigned this Dec 17, 2024
alvarosabu added a commit that referenced this issue Jan 2, 2025
* feat(Bounds): add component, demo, docs

* refactor(Bounds): useScreenSize -> useResize

* refactor(Bounds): rename variables, remove unneeded state

* docs: fix material items merge issue

---------

Co-authored-by: alvarosabu <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature New feature or request p2-nice-to-have Not breaking anything but nice to have (priority)
Projects
Status: No status
Development

No branches or pull requests

2 participants