please help. I have an image like the one below that is displayed on the home page (a larger image). Note that the "FORGE" house has a white and blue marker in the middle with a black arrow.
The same goes for “rental” homes.
Each of these tags will act as an interactive button. The following is the expected interaction behavior:
Also want it to be responsive if and when the screen is resized the buttons should stay in these specific positions.
I'm trying to use absolute positioning, x,y coordinates to try and make it work. But since I enjoy the experience of this type of user interface, I can't find a working solution. Not sure if I should use canvas or something else.
Any help would be greatly appreciated.
My code looks like this, but it looks like I'm not on the right track:
const ImageComponent = () => { const markers = [ { name: 'Forge', x: 100, y: 200 }, { name: 'Rentals', x: 300, y: 150 }, // Add more ]; const handleMarkerClick = (m) => { // do something with marker }; return ( <div style={{ position: 'relative' }}> <img src="path/to/image.jpg" alt="Image with markers" /> {markers.map((marker, index) => ( <div key={index} className="marker" style={{ left: marker.x, top: marker.y, position: "absolute" }} onClick={() => handleMarkerClick(marker)} /> ))} </div> ); };
You should place the control absolutely in the image container. Implementation depends on a variety of factors, such as where the image is placed, whether it is full screen, whether there is content before or after the image, etc. But this code should show you the main principle.
If the image is resized when the window is resized, a container that is identical to the image should be created. You can then set the position of the controls relative to that container and anchor them to their respective points.
Using your code, it will look like this (but I recommend moving your styles in the styles file to learn how to use module styles in react ):
Just fix the position and add a normal control view.
For control you should make separate components. Here's an example of how to achieve the behavior you want: