I create a small game prototype to check the new Unity features.
URP and Post Effects are working well but VFX (Compute Shader) do not display at all, only on my PC.
Is it supported on Android devices?
Tested using 2 Android, Mali and Snapdragon.
I create a small game prototype to check the new Unity features.
URP and Post Effects are working well but VFX (Compute Shader) do not display at all, only on my PC.
Is it supported on Android devices?
Tested using 2 Android, Mali and Snapdragon.
Hi,
For now, the URP support is limited to mobile supporting Compute Shader and Shader Storage Buffer Object (SSBO) in a vertex stage.
We are also working on CPU simulation for non compute capable devices.
About android devices, most of the Mali doesn’t support SSBO, about Snapdragon, it depends on the embedded Adreno version.
thank you so much for your answer.
one more quesiton, is there a way to check if the mobile gpu support SSBO?
Yes, you can simply check this value https://docs.unity3d.com/2019.3/Documentation/ScriptReference/SystemInfo-maxComputeBufferInputsVertex.html is greater (or different) than zero.
bool supported = SystemInfo.supportsComputeShaders && SystemInfo.maxComputeBufferInputsVertex != 0;
Thank you, for VFX Graph tool how many should i have ? 128? Depends of the effect?
My device mark true for ComputeShader as before, i add the SystemInfo.maxComputeBufferInputsVertex and i got a value of 4.
I did more tests using multiple phones, effects visual fidelity depends on the Vertex Buffer count.
4, nothing
24 show with errors
and go on.
I will mark this as close, at this state Graph VFX is unusable on android devices, even in prototype state.
Will come back here one year later.
Thank you again.
You can keep an eye on a similar issue happening on Adreno device using GLES3. We are planning a fix in the Unity 2020 cycle.
I understand your frustration, we are working hard on these platforms issues.
Thank you for sharing your concern.
Effect team in charge of making effects prototype do love the VFX Graph. But saddly we focus on mobile games.
For now wait is better
Keep the good work!
Yes we strongly advise to wait for VFX Graph being production-ready for mobile before using it for any production targetting mobiles.
Hey, @JulienF_Unity thanks for getting back with us on this. Would it make more sense for the VFX Graph to be marked as still in “preview” then? At least for certain platforms. That or maybe in the description of the package flag certain platforms as “preview” and some as “verified”. That way it would prevent teams such as ours from spending time using it for mobile development (or VR as other people have pointed out) just to find out that it isn’t yet supported on that platform.
Don’t misunderstand me. We are very excited about the VFX Graph and very much enjoyed what we have used it for so far. It’s just frustrating to spend time on something thinking it’s out of preview but it’s not.
TL;DR; We should mark certain platforms such as mobile and Oculus Quest as “preview” and other platforms such as desktop as “verified” in order to prevent developers from spending a lot of time using a tool thinking it is “verified” for all platforms because it is marked as “verified” in the package manager.
Edit: typos
Hi @TCROC , you are completely right about the per-platform information and we are discussing ways of unifying this across different packages to make this more visible. This should probably include also Graphics APIs and SRPs. In hindsight, communicating the out of preview is not sufficient without the in preview bits, and a clear platform/SRP/Graphics API matrix should be included.
Thank you for sharing your feedback, we will look into the best way to implement this!
And can we have any idea when it could be ?
Hi, should be within a year; please feel free to upvote it on the public roadmap.
Ooops. I was hoping to use VFX Graph on an Oculus Quest project. When using UniversalRP, at least the shaders compile. With legacy (what we usually use for our project), we’re getting some shader compilation errors. It’s the same error as reported here , but I don’t know how to fix it when using legacy instead of UniversalRP.
With UniversalRP and Visual Effect Graph 7.3.1 (and Unity 2019.3.12), apparently the line renderers work (e.g. the lightning in the demo package) but the regular particles render as lines, so e.g. the fire from the demo package is badly broken.
Another concern, of course, is performance … but first step is making it work at all.
Hi @jashan ,
The VFX Graph is fully supported with HDRP-only at the moment.
URP has partial implementation (currently still missing a few items to reach parity, such as Lit shaders, camera buffer access, sorting against other non-VFX systems, and of course the mobile support which is more relevant for URP than HDRP.)
The VFX Graph is not supported on the built-in renderer; it is intended to be used with the SRPs.
Do you mean in the editor, or when you built on the Oculus Quest?
If it’s the latter, that’s part of the mobile support that’s still pending: https://fogbugz.unity3d.com/f/cases/1149057/
The way we currently use it, on desktop and PS4, what is implemented with the legacy render pipeline is fully sufficient.
HDRP added way too much overhead for VR the last time I checked, and performance of Universal RP is also noticeably worse when testing on Quest (that’s performance in general, not specific to VFX Graph or PostProcessing). The only reason I have seen so far to use Universal RP is because PostProcessing V2 is completely broken with legacy on Quest - but while the URP PostProcessing does work on Quest in principle, it adds too much GPU processing to actually be usable on that device.
Besides, switching over to Universal RP would require a lot of porting work.
It may not be officially supported for the built-in renderer but actually works quite well with it. There is a folder com.unity.visualeffectgraph@7.3.1\Shaders\RenderPipeline\Legacy included for that, and has been since the earliest alphas. I had created my first VFX prototypes using HDRP but then quickly moved back to legacy. Admittedly, the quality with HDRP was superior - but performance with legacy was so much better that the lesser quality was a decent trade.
Desktop (PC) and PS4 works fine, only Quest gives me shader errors during builds when using legacy. Those shader errors disappear when switching to URP but rendering VFX Graphs on Quest is buggy, as described in my previous posting.
On the Quest. I have never seen issues in the editor.
The page requires login to FogBugz and I don’t have a login.
The challenge here is that it works until it doesn’t. We’ve left these shaders there because some users wanted to have the option of maintaining it on their end, but because it is not officially supported, anyone using it has to also accept that it might not work on certain platforms, or that they may reach a point after which it won’t work in future versions. The built-in particle system is still the most straight-forward option for particles in the built-in renderer.
Apologies, here’s the public issue tracker link. Basically, if you are getting any of this craziness, it’s the issue discussed in this thread.
Interesting, I wonder if you could share more info on this? The URP team is working hard on ironing out all the kinks out, and in theory it should out-perform the built-in renderer. If you’ve noticed that isn’t the case with the Quest, perhaps with a bit more info it’s something my colleagues can investigate more.
I understand that. It was announced from the beginning that legacy isn’t the focus for VFX Graph, so I’m well aware that I’m taking a bit of a risk, and super-happy that I can take that risk and things didn’t break until 2019.3.14 / 7.3.1. If a VFX Graph or Unity update breaks legacy, it will probably mean I’ll stay on the last version where it worked for the time being. I used to always be on the latest alpha of Unity a long time ago (when alphas were still only available under NDA) but became a lot more conservative in the last few years. Currently, Unity 2020 is not on option for us due to lots of breaking changes in how VR is handled.
I do try URP (and previously LWRP) every once in a while to see if it has become a viable option for our project. That’s how I found out that VFX Graph shaders do compile for Quest (which is one step towards porting our game for Quest) but there are still showstopper issues (performance, which is expected, and artefacts):
Yeah, that does look very much like it. Basically, my next step with this is reviewing VFX Graph / URP for Quest again once the obvious issues are fixed, and I believe URP performance is now also a strong focus of the team working on it.
Unfortunately, like so often in Unity in the last few years, the approaches between Shuriken and VFX Graph are so fundamentally different that moving back and forth between those systems is not really an option. PostProcessing is another “great” example, so are the render pipelines, or networking. It’s a true nightmare because basically, Unity has turned from a unified tool capable of lots of different things into a chaotic toolbox where you need to work with completely different tools, to achieve the same results, depending on what other tools you are already using.
The way I would expect this to work in an authoring tool like Unity:
Obviously, the render pipelines should follow the same approach. At some point, legacy would factually become obsolete (because you can do everything you could do with legacy also with URP, and there’s a straightforward upgrade path that doesn’t require recreating half your existing game). Once any given system is factually obsolete, it can be deprecated and only kept for the current LTS, and then completely removed in the next “major release” of Unity.
I’ll look into it. That was a comparatively simple test project, anyways, so shouldn’t be too hard to file it as a bug report. Unfortunately, legacy and URP are so different that properly setting up tests like that takes a lot of time that I could also spend developing my game. Had the approach I outlined above been properly followed, doing that kind of test would just be a matter of changing the render pipeline setting back and forth between legacy and URP. But as it is, it basically means keeping two projects with lots of places where the same setting (e.g. anti-aliasing) is in completely different places.
That said … is there maybe an easy way to fix this shader compilation error?
Shader error in 'Hidden/VFX/EffectName/System 1/Output Particle Quad': invalid subscript 'stereoTargetEyeIndex' at /Program Files/Unity/Hub/Editor/2019.3.14f1/Editor/Data/CGIncludes/UnityCG.cginc(786) (on gles3)