Coder Social home page Coder Social logo

Comments (14)

Adrian-Samoticha avatar Adrian-Samoticha commented on August 19, 2024 4

Alright, some progress: πŸ™‚

image

What's cool is that Visual Effect Subviews still work perfectly fine. What isn't cool is that miniaturizing/restoring the window causes significant performance issues and interestingly, Flutter-drawn widgets have a shadow applied to them, but it isn't being updated, so the window can quickly end up looking like this:

image

Either way, I'm happy to have progressed on this issue and will try to fix those issues.

from flutter_acrylic.

Adrian-Samoticha avatar Adrian-Samoticha commented on August 19, 2024 3

Alright. I am sorry that it took me over eight months to resolve this issue, but #48 finally resolves it. However, there is a little bug that I couldn't fix (#49), so please be aware of that.

from flutter_acrylic.

Adrian-Samoticha avatar Adrian-Samoticha commented on August 19, 2024 2

The macOS port offers a variety of different WindowEffects that map to equivalent NSVisualEffectView.Materials.

I have tried to make the Windows-only WindowEffects map to macOS Materials that are β€œas close as possible” to their Windows counterparts, but obviously, they aren't going to be the same.

None of those materials are completely invisible, though. That said, I believe there is some way to achieve what you want. The macOS terminal offers a way to customize both the opacity and the blur effect of the terminal window:

Screen Shot 2022-03-16 at 11 41 57

I'm not going to assign myself just yet, but I might do some research to find out if (and how) something like this may be possible.

from flutter_acrylic.

Adrian-Samoticha avatar Adrian-Samoticha commented on August 19, 2024 2

Apparently making it possible to control the window's opacity and blur radius the same way the macOS terminal does is not really feasible since it relies on CGSSetWindowBackgroundBlurRadius, which is part of a non-public API whose usage may result in your app breaking in the future (and Apple does indeed deny App Store submissions if they happen to contain calls to this API).

Though if I understand correctly, all you're after is a way to make the window completely transparent, leaving only the Flutter view to be visible? That may be possible, although I'm unsure how well that would integrate into the current project structure.

from flutter_acrylic.

Adrian-Samoticha avatar Adrian-Samoticha commented on August 19, 2024 1

Any update on this?

It's on my radar, though not actively being worked on at the moment.

EDIT: What's interesting, is that while I was initially developing the macOS support, I somehow managed to trigger a bug that actually achieved exactly what @dlewis2017 is requesting (the window got entirely invisible), but I cannot remember how I triggered it, nor do I know how well it can be implemented in the code base.

I'll take a look at that when I get some free time.

from flutter_acrylic.

dlewis2017 avatar dlewis2017 commented on August 19, 2024 1

Appreciate it! @Adrian-Samoticha

from flutter_acrylic.

dlewis2017 avatar dlewis2017 commented on August 19, 2024

Not a bug. Just make sure to set the alpha to 0.
await Window.setWindowAlphaValue(0.5);

from flutter_acrylic.

dlewis2017 avatar dlewis2017 commented on August 19, 2024

Sorry for all the comments but this may actually be a bug. I want just the background to be transparent. Not all components within it. Equivalent code should ideally produce the same effect in different systems for Flutter.
As you can see with the Mac application, the whole screen is see through when the alpha is set. When the alpha is not set, the transparency isn't working well. In Windows it works as intended.

no alpha set
Screen Shot 2022-03-15 at 4 56 43 PM

alpha set to .5
Screen Shot 2022-03-15 at 4 57 17 PM

windows
Screenshot 2022-03-15 165348

from flutter_acrylic.

alexmercerind avatar alexmercerind commented on August 19, 2024

Not all the effects are available on every platform, same for the available functions.
Both, macOS & Windows do it differently, we do not mimic the effect within Flutter but use system's APIs to achieve it. There is no way to make behaviour exactly the same, just pick the best one you find according to your requirement on each platform.
Infact, on Windows this acrylic effect is limited to UWP apps, but this plugin does achieve it after a "hack" in Windows 10.

from flutter_acrylic.

dlewis2017 avatar dlewis2017 commented on August 19, 2024

Okay cool, I appreciate you potentially looking into it! I'll use the alpha for now set to .6/7 if Mac is the OS

from flutter_acrylic.

alexmercerind avatar alexmercerind commented on August 19, 2024

Windows implementation is also completely undocumented in this plugin for Windows 10.
However, I guess real issue will be rejection by Apple's App Store. And I guess, not a good thing.

from flutter_acrylic.

dlewis2017 avatar dlewis2017 commented on August 19, 2024

@Adrian-Samoticha Thanks for looking into that. My goal was to make the Flutter window transparent while leaving inside components visible. So to mimic how it looks in Windows above, but in MacOS. As of now it seems MacOS doesn't make the window transparent, and using the work around (setting the alpha) causes everything to be transparent.

from flutter_acrylic.

qshanahan-springhealth avatar qshanahan-springhealth commented on August 19, 2024

Electron seems to support this out of the box:

https://www.electronjs.org/docs/latest/api/browser-window
search for "transparent"

seems to also have cross platform support. I don't see any usages of CGSSetWindowBackgroundBlurRadius, is it a special case somehow because they are using chromium?

from flutter_acrylic.

krjw-eyev avatar krjw-eyev commented on August 19, 2024

Any update on this?

from flutter_acrylic.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.