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

Duplicate Screen Breaks the layout #107

Open
Paradnor opened this issue Jul 4, 2024 · 12 comments
Open

Duplicate Screen Breaks the layout #107

Paradnor opened this issue Jul 4, 2024 · 12 comments

Comments

@Paradnor
Copy link

Paradnor commented Jul 4, 2024

Hello and thank you very much for the library.

Lately I did a dev with it to place seats over the layout.

However, when my laptop is in "Duplicate Screen" mode, all the layout is broken. Those seats go on the top left corner.

Is there any way to fix that ?

Many thanks

@tbee
Copy link
Collaborator

tbee commented Jul 4, 2024

You should really provide more information. Screen shots, a simple code example, ...

@Paradnor
Copy link
Author

Paradnor commented Jul 4, 2024

As a start,
Here the normal situation (Either with "Screen only" or "Extended" mode)
image

Here the situation when I'm in "Duplicate screen" mode
image

I'll try to produce a sample code reproducing the issue after my working day :)

@Paradnor
Copy link
Author

Paradnor commented Jul 8, 2024

Hello !

Sorry for the late reply. I was busier than expected.

Here is a simple code example :

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.stage.Stage;
import org.tbee.javafx.scene.layout.MigPane;

public class Sample extends Application {
    @Override
    public void start(Stage primaryStage) {
        primaryStage.setTitle("MigLayout JavaFX Example");

        // Creating a MigPane with column and row constraints
        MigPane migPane = new MigPane("wrap 1", "[grow]", "[][grow][]");

        // Adding components to the MigPane
        migPane.add(new Label("Top Section"), "cell 0 0, wrap");
        migPane.add(new Button("Middle Section"), "cell 0 1, grow, wrap");
        migPane.add(new Label("Bottom Section"), "cell 0 2");

        // Setting the scene
        Scene scene = new Scene(migPane, 400, 300);
        primaryStage.setScene(scene);
        primaryStage.show();
    }

    public static void main(String[] args) {
        launch(args);
    }
}

To explain the problem more clearly, all is fine while I stay in "First Screen only" or "Extend" display mode from Windows. As in the following picture :
image

However, when I set my display mode to "Duplicate", the layout seems to break somehow :
image

It is like the layout recomputes its size and its components size as well. However, when I duplicate my screen I think it should keep the "First Screen" resolution and so shouldn't recompute them.

Any help or explanation would be appreciated.

Thanks :)

PS : I forgot to tell, it is on Javafx library 11.3 with OpenJDK 21.0.2

@tbee
Copy link
Collaborator

tbee commented Jul 13, 2024

Just to check if this is a MigPane or MigLayout issue, what happens with the swing equivalent?

import net.miginfocom.swing.MigLayout;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.SwingUtilities;
import java.awt.Dimension;
import java.lang.reflect.InvocationTargetException;

public class TestSwing {
    public static void main(String[] args) throws InterruptedException, InvocationTargetException {
        SwingUtilities.invokeAndWait(() -> {
            MigLayout layout = new MigLayout("wrap 1", "[grow]", "[][grow][]");
            JPanel pane = new JPanel();
            pane.setLayout(layout);
            pane.add(new JLabel("Top Section"), "cell 0 0, wrap");
            pane.add(new JButton("Middle Section"), "cell 0 1, grow, wrap");
            pane.add(new JLabel("Bottom Section"), "cell 0 2");

            JFrame frame = new JFrame("Test");
            frame.setContentPane(pane);
            frame.setSize(new Dimension(600, 400));
            frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            frame.setVisible(true);
        });
    }
}

@Paradnor
Copy link
Author

The swing equivalent is stable :)

@Paradnor
Copy link
Author

Any update about this issue ? :)

@tbee
Copy link
Collaborator

tbee commented Aug 26, 2024

Back from vacation. I've been able to reproduce your problem. Weird. I would expect problems in extend mode, but not here. Will have to play with that a bit.

@tbee
Copy link
Collaborator

tbee commented Aug 31, 2024

Okay, I've started to take a look. My first question is: if you're doing cell based layout, why are you using the "wrap" constraint? Wrap is intended for flow based layouts and wraps to a new row. If you're specifying the cell positions, wrap does not make sense?

@tbee
Copy link
Collaborator

tbee commented Aug 31, 2024

I found the cause, don't know a solution yet.

In MigPane the screen's DPI is used to convert logical sizes to actual pixels, in duplicate mode JavaFX reports the DPI as 0, which causes a.o. the gap calculations to result in 0 gaps. In extended mode each screen has it's own DPI (in my setup 93 and 113) and the logic works correctly.

MigLayout of course bases itself on the info JavaFX provides, so I don't know how to fix that. Using a default DPI of 96, in case 0 is returned, seems not correct either, but apparently that is often used .

@Paradnor
Copy link
Author

Okay, I've started to take a look. My first question is: if you're doing cell based layout, why are you using the "wrap" constraint? Wrap is intended for flow based layouts and wraps to a new row. If you're specifying the cell positions, wrap does not make sense?

To be honest it is probably my misunderstanding of the library. It was the first time I use it ! :)
From your comment, I guess it makes no sense indeed ! :)

I found the cause, don't know a solution yet.

In MigPane the screen's DPI is used to convert logical sizes to actual pixels, in duplicate mode JavaFX reports the DPI as 0, which causes a.o. the gap calculations to result in 0 gaps. In extended mode each screen has it's own DPI (in my setup 93 and 113) and the logic works correctly.

MigLayout of course bases itself on the info JavaFX provides, so I don't know how to fix that. Using a default DPI of 96 in case 0 is returned seems not correct either, but apparently is the often the default value.

Thank you very much for your investigations !

@tbee
Copy link
Collaborator

tbee commented Aug 31, 2024

Using 0 for the dpi seems more wrong than a decent default, so I've released MigLayout 11.4.1. Give that a try if you will.

@Paradnor
Copy link
Author

Thank you very much. I just gave it a try and the behavior is better than previously.

image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants