On Sun, 20 Oct 2024 01:23:01 GMT, Michael Strauß <mstra...@openjdk.org> wrote:
>> This PR is a new take on a highly requested feature: JavaFX controls in the >> header bar (see also #594 for an earlier iteration). >> >> This is a feature with many possible ways to skin the cat, and it has taken >> quite a bit of effort to come up with a good user model. In contrast to the >> previous iteration, the focus has shifted from providing an entirely >> undecorated window to providing a window with a user-configurable header bar. >> >> The customizable header bar is a new layout container: >> `javafx.scene.layout.HeaderBar`. It has three areas that accept child nodes: >> leading, center, and trailing. `HeaderBar` also automatically adjusts for >> the placement of the default window buttons (minimize, maximize, close) on >> the left or right side of the window. >> >> The customizable header bar is combined with a new `EXTENDED` stage style, >> which extends the client area into the header bar area. The new extended >> stage style is supported on Windows, macOS, and Linux. For platforms that >> don't support this stage style, it automatically downgrades to `DECORATED`. >> >> This is how it looks like on each of the three operating systems: >> >> data:image/s3,"s3://crabby-images/081d1/081d102099b8b5d8cd3cbf54d923a8f83f4c7efa" alt="extendedwindow" >> >> The window buttons (minimize, maximize, close) are provided by JavaFX, not >> by the application developer. This makes it easier to get basic window >> functionality without recreating the entirety of the window controls for all >> platforms. >> >> ## Usage >> This is a minimal example that uses a custom header bar with a `TextField` >> in the center area. `HeaderBar` is usually placed in the top area of a >> `BorderPane` root container: >> >> public class MyApp extends Application { >> @Override >> public void start(Stage stage) { >> var headerBar = new HeaderBar(); >> headerBar.setCenter(new TextField()); >> >> var root = new BorderPane(); >> root.setTop(headerBar); >> >> stage.setScene(new Scene(root)); >> stage.initStyle(StageStyle.EXTENDED); >> stage.show(); >> } >> } >> >> To learn more about the details of the API, refer to the documentation of >> `StageStyle.EXTENDED` and `HeaderBar`. >> >> ## Platform integration >> The implementation varies per platform, and ranges from pretty easy to quite >> involved: >> 1. **macOS**: The window buttons are provided by macOS, we just leave an >> empty area where the window buttons will appear. The client area is extended >> to cover the entire window by setting the `NSW... > > Michael Strauß has updated the pull request incrementally with one additional > commit since the last revision: > > revert unintended change Adding some more examples. Vivaldi browser actually allows you to switch between to modes: data:image/s3,"s3://crabby-images/2b7cf/2b7cf4abfcd03e92fa2121a4350365cdea8c3ffd" alt="image" which can be switched with data:image/s3,"s3://crabby-images/a95fe/a95feec3e87cba78670229ecaa6a4c61af96bd1c" alt="image" to data:image/s3,"s3://crabby-images/c5d8d/c5d8da68b47b53d72d7dd2c1c732636bcd130840" alt="image" So in the first mode, the menu is compressed vertically into the Vivaldi button. Here is Discord: data:image/s3,"s3://crabby-images/86356/863568108b60c3a93435dc2cff7c839cbcf8df5b" alt="image" Very compact. As for the payout of this feature, while personally I don't have a need for it, I will probably use it if it's not too much trouble. Regardless of my own opinion, this has been one of the most requested features, along with tray icon support, and it's available in the main "competition" frameworks. I would say that a very strong case will need to be made for this to *not* be added. The question that remains, as it often does, is if this is the right implementation. Hopefully the review process will figure that out. ------------- PR Comment: https://git.openjdk.org/jfx/pull/1605#issuecomment-2428966767