POT and NPOT textures problem

Hello everybody,
We need to make pretty simple thing - texture GUI for online application and we stuck with one problem.

All objects used in GUI (buttons, panels, windows) have arbitrary size: for example, most buttons have size 30*80 px.

If we make texture for button of exact size (30*80 px, i.e. Non Power of Two, NPOT), then button looks blurry.
As I understand, this happens because old cards (like mine Radeon 9600) cannot work natively with NPOT textures and resize them to closest POT size and this resize ruins quality of texture.

OK, now we make texture of closest POT size and place image of button into upper left corner of texture, like this:

(not real texture, just sample)

The problem now is UV-mapping this texture to 30*80 button.
How that can be done?

P.S. Sorry for my awkward english.

using NPOT textures in the GUI works just fine. If you configure the import settings to scale the textures, they will get blurry. If you just leave them at the default value, you will be just fine using NPOT.

And is it possible to map texture like in message above?

Just as performance and compatibility tweak:
As I understand, cards like R9600 can render NPOT textures without software resize, but only using special extensions (in OpenGL terms), and there are even more old chipsets, which doesn’t support NPOT textures at all.
So storing GUI textures like WoW does (sample texture is taken from there) is best choice if you want your app to be maximum fast and compatible.

The GUI System works a bit different than regular 3d models. Even if you don’t provide power of 2 it will still meet the gpu requirements as the textures are used as part of the GUI within the GUI system, not on their own.

and no, you can’t do UV transformations on GUI.xxx
You would need to create your own gui system if texture atlas functionality is what you are looking for.

And if UV-mapping is not possible for Unity GUI system, is it possible to hide with transparency “excess” parts of textures?

i.e. actual panel height is 32 px, but excess 2 pixels are invisible.
Won’t there be any problems, for example with “overlapping” buttons?

I won’t get the terms right, so I’m not gonna use them. Create a photoshop image with a transparent background or painted alpha channel and add it to your assets. Or export it to PNG for instance if you so desire.

This image will import just fine with its transparency for instance:

(Ok perhaps I went just a liiittle too far in my promotion there :wink:)

You should just use NPOT textures.

If they come out blurry, then there’s something wrong somewhere (and it would be good to know what you’re doing that makes them blurry).

And do not worry about hardware support; we do store textures at NPOT size (to save space), but at load time we create a texture that is next power of two, and pad that texture with dummy pixels (and if original NPOT texture is DXT compressed, we blit the DXT compressed blocks and fill the rest with dummy DXT blocks - so the resulting texture is still DXT compressed). And then we do some magic so that GUI that uses that texture is still always referencing the correct portion of that “padded up” texture.

In other words, don’t worry :slight_smile:

Wow! Thanks for such detailed answer.
We made GUI with NPOT textures, everything is OK, no blur.
“Don’t worry” was good advice in this case :slight_smile:

The documentation states that compression of NPOT textures is only possible if they are exclusively used on GUITextures. Are you saying that it is also possible if they are exclusively used in GUI(Layout)? We have a project with a lot of NPOT textures being used in the GUI, and it looks like they’re taking a ridiculous amount of main memory in the player—removing them frees up 800MB. All of the textures use default import settings, and are being used only in GUI calls. Are they being compressed?

Hello, I and my team has made a tool to change the NPOT texture to POT texture. However it’s just released, and it’s free. It helps in reducing Memory on Android and IOS. Also disk space in your project. Check it out and share it with your fellow Unity developers. NPOT to POT Textures