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

Frameless windows #417

Open
2 tasks
vaykinov opened this issue Jun 15, 2024 · 4 comments
Open
2 tasks

Frameless windows #417

vaykinov opened this issue Jun 15, 2024 · 4 comments
Labels
enhancement New feature or request

Comments

@vaykinov
Copy link

Describe the Feature

The ability to hide the default title bar in browsers, thus enabling the possibility of creating a custom one.

Use Case

I'm currently trying to develop a desktop web app. It's not my first time building one, as I've start by using frameworks like Electron and Tauri.

If I understand correctly, this is not a framework but a library that enables the developer to create such apps with pretty much any backend language. Its mission is not to try and add all the functionalities that exist in the previously mentioned frameworks (or any others for that matter).

I've seen this commented on before (discussion and some comment on an issue found on the same discussion), but I can't seem to make it work on my end.

I've also seen that the feature "kiosk mode" is already available, but I also think that this one could enhance the desktop app, making it feel more like a desktop app rather than a fancy web browser (which it still is), and there are already multiple apps that have this feature (Teams, Discord, VS Code, and others).

But if the frame/title bar is hidden, we also need API calls to minimize, maximize, and close the app. I know I can close the app by binding a call from the backend, but I'm not sure about the other ones.

Proposed Solution

I guess it can be done the same way as with kiosk mode: void webui_set_frameless(bool status).

I'm not sure how the other three calls should be implemented, but I would like to have the calls available in webui.js as well, the same way as webui.isConnected().

Other Information

No response

Implementation

  • I may be able to implement the feature.
  • It might incur a breaking change.

Version

WebUI v2.4.2

Environment details (OS name and version, etc.)

AMD64 Family 25 Model 33 Stepping 0 (???)
@vaykinov vaykinov added the enhancement New feature or request label Jun 15, 2024
@hassandraga
Copy link
Member

WebUI uses a web browser as GUI, making your app lightweight and not depend on anything except a web browser (which is installed pretty much on every system). This is great, but the limitation is that the window belongs to the web browser and not to the backend app, I mean by that, custom options can be available only if the web browser provides it, in this case, hiding the title bar can be done in Firefox, and not in other web browsers for now.

If a developer needs the app to function as a default desktop window, lightweight and portable as possible, then using the web browser window is the best option. However, if more custom options are required, the recently added WebView window in WebUI v2.5 Beta is the ideal choice.

In conclusion, your proposal can be made using WebView (WebUI +2.5) and some web browsers (Firefox for now).

This is an excellent feature to have. We will try to implement it. Thank you for the proposition @its-mr-kin.

@vaykinov
Copy link
Author

I didn't know that it was possible with that version and with Firefox. When I find more time, I'll try it out.

To be honest, I would try to implement it myself and make a PR, but I have a problem: I don't understand the code, in the sense that I didn't write it, and I don't have a good grasp of the architecture/project.

The only way I can think of to learn how to understand the project is by reading it from start to finish and then trying to do things, but I don't think I have enough understanding to keep up with the project. So, sorry I can't help now (I really wish I could, since I like the project so far).

If it's of any help, or if it sounds useful, I could publish the template I'm building for my app. It's just Solid-ts as the frontend, and I'm using zig-webui as backend. I'll also be creating the webui.d.ts (since it's needed for TypeScript projects) that could allow building apps with any TypeScript framework. But, once again, I'm creating this for myself and to learn, so I'm not sure if it will be useful.

Anyway, thank you for considering implementing it, and if the idea of publishing the template or the d.ts sounds useful, I could do it.

@malisipi
Copy link
Contributor

I may work about an external C/C++ library that manipulates windows on Windows. (It will not be related directly with the WebUI to avoid harming the portability of WebUI, however WebUI will be first class citizen). Technically I would support changing title, icon, opacity, appearance (including with the borders/frames) and placement Windows internal APIs. Even more if I find a way to adjust the background, I may support DWM effects like Mica or Acrylic.

It would be good to support fluent web components on Mica background. It also may increase the interest of WebUI.

@pabloko
Copy link

pabloko commented Aug 10, 2024

This is related only to WebView2 on windows, you can easily create "offscreen" web views and render them with hardware acceleration into D3D11 textures. The only catch is that you have to pass input events to the compositor. I created a sample gist will all the things you need to make it work.

You can use it straight away as game overlay or inside your composition pipeline

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

No branches or pull requests

4 participants