Changing loading screen with image from assets directory within Playcanvas


#1

Hi

I’m trying to change the loading screen with the logo from my Company.

So far it works with a Http link that gets the image from the website.

var logo = document.createElement(‘img’);
logo.id = ‘logo’;
logo.src = “http://www.dstudio.be/logo.jpg”;
splash.appendChild(logo);

Is it possible to use an image that I have uploaded to the assetsfolder within the editor.
I want to edit the picture in photoshop and upload it to playcanvas and then use it as a logo for my loading screen.
I’m not sure how to do that.
Can somebody help me with that? Much appreciated.

Greetings


#2

Are you on the Organisation Plan? https://playcanvas.com/plans

If so, there is support for changing the loading screen within the editor: http://developer.playcanvas.com/en/user-manual/designer/loading-screen/


#3

Hi

Thanks for the response. Yes we have an organisation Plan.
I found the loading screen support, but it doesn’t really show me how to change logo with a image from within the editor.
It only shows how to use a http link as a source.

I don’t really know how to write the code so it kan use png file from assetsfolder.
Normally you can add an asset by dragging it to the script after defining it within the code but this is not possible here.


#4

Sorry, I completely glanced over your actual question over my morning rush and should have given you a proper answer in my last reply.

I’m afraid it isn’t possible to use an asset within the project for the loading as the loading screen script is executed prior to the assets registry being created and accessible. Also, when you publish on our servers, the files are exported to a unique publish directory so the file URL is different for every published build so it is not possible to know the file URL ahead of time and therefore not possible to hard code.

If you are exporting the build to host on your own server (Publish -> Download build and host on your own server), it is possible to know the file URL ahead of time as the file structure is always the same (/files/assets/XXXXXX/X/filename.jpg).

A possible workaround is to encode the image as base64 using a service like this: https://www.base64-image.de/ and paste the data string in as source. e.g:

        var logo = document.createElement('img');    
        // This data is truncated to fit within the forum reply limit. 
        // The project link below has the full data string
        logo.src = '';
        splash.appendChild(logo);
        logo.onload = function () {
            splash.style.display = 'block';
        };

Example project: https://playcanvas.com/project/457948/overview/using-base64-for-loading-screen

Not ideal but it allows you to keep the logo within in the project in some form and not have to host the image elsewhere.


#5

Hi

Thanks- the base64 solution works great.
Appreciate the help!


#6

Turns out I was wrong @radudordea :sweat_smile:

It is possible to access the asset registry at some point during the loading screen as an event is fired when the engine is about to preload the assets which means that the asset registry is available.

Please see this project for more details: http://developer.playcanvas.com/en/tutorials/advance-loading-screen/

Once caveat to remember is that any non power of 2 images uploaded to the project are automatically converted and scaled to fit in power of 2 sizes which may not be desirable from a quality point of view.


#7

You can decide whether to resize non-power of two images when you import in the scene settings under “Assets”.


#8

Thanks for the help will try it !


#9

Can you describe briefly what the pros and cons of that are, or point me to a good reference? Does not having the conversion help the render engine process things faster, etc.?

Thanks a bunch!!


#10

From here:

By default, imported images will be resized to the next highest power of two. For example, an image that is 400x400 will be resized to 512x512 on import. This is done because the graphics engine cannot utilize mipmapping with non-power of two textures. However, this behavior can be overridden by disabling the ‘Textures POT’ setting in the Asset Tasks panel before importing a non-power of two texture.


#11

In addition to Dave’s answer, one of the texture compression is not available for non POT textures.


#12

Got it! So which is better will vary depending on your situation, memory constraints/usage and how much the texture is moving about relative to the camera.

Reading through that link about I question I’ve had regarding the use of RGB images for alpha (opacity) textures. An opacity channel is only ever 8-bit. That’s why the Opacity Panel gives your the option of using R,G,B or A channels for an RGB or RGBA image. So, is graphic memory conserved by using only 8 bit alpha (opacity) textures, or does the fact that only one channel is selected for use effectively conserve memory in the same way?

I know this is now drifting off the original topic, but I promise not to take it off track any further. Or I can always re-ask with a new topic if that would be preferred.

Thanks again!!