Java-Gaming.org    
Featured games (91)
games approved by the League of Dukes
Games in Showcase (579)
games submitted by our members
Games in WIP (500)
games currently in development
News: Read the Java Gaming Resources, or peek at the official Java tutorials
 
    Home     Help   Search   Login   Register   
Pages: [1]
  ignore  |  Print  
  LibGDX - StillModel mesh - dispose?  (Read 619 times)
0 Members and 1 Guest are viewing this topic.
Offline ddfh

Senior Newbie





« Posted 2013-05-14 09:05:55 »

Hi,

I have 16 Levels. In each level, I have a different 3d environment (mountains, buildings, volcano etc.).

Now When I go to Level 2, I don't need anymore the environment of Level 1.

How can I now free the memory of this meshes?
For example:
1  
2  
   StillModel mountain;   
   StillModel buildings;  
Offline gouessej

« In padded room »



TUER


« Reply #1 - Posted 2013-05-14 10:17:30 »

Hi

I don't know whether it is already supported in LibGDX but if it isn't, let me help you out. I have a similar problem in my first person shooter. The first level uses a museum with some soldiers but the second one uses a completely different environment.

An easy step consists in keeping no reference on these meshes (and maybe on their textures too) so that the garbage collector can do its job with Java objects on the Java heap.

Another (less) easy step consists in releasing OpenGL resources (mainly the identifiers), by calling glDeleteBuffers for all VBO identifiers and by doing something similar with textures.

The hardest and less safe step consists in releasing the native memory on the native heap, typically used by direct NIO buffers. You can find tons of examples on Internet to "destroy" direct NIO byte buffers by using their cleaners. However, if LibGDX doesn't create them by using allocateDirect(), it won't work. You will need to treat the viewed buffers differently. If you use a direct NIO buffer after releasing its native memory, you will get an access violation error  Sad Lots of 3D engines and APIs use asFloatBuffer(), you can't retrieve the cleaner so easily in this case, you need to make some supposition on how they are implemented, you have to get the real direct NIO byte buffer contained by this fake float buffer and then you can use the cleaner as usual.

@davedes feel free to make a better suggestion

Edit.: You have to ensure the backend you use (based on JogAmp or on its competitor) do not keep references on deleted buffers (typically after calling glDeleteBuffers) or you may have some big problems.

Offline gouessej

« In padded room »



TUER


« Reply #2 - Posted 2013-05-14 12:42:06 »

This page explains a bit how it works in LibGDX.

Games published by our own members! Check 'em out!
Legends of Yore - The Casual Retro Roguelike
Offline ddfh

Senior Newbie





« Reply #3 - Posted 2013-05-15 16:24:29 »

Thank you! That helped me.
Pages: [1]
  ignore  |  Print  
 
 
You cannot reply to this message, because it is very, very old.

 

Add your game by posting it in the WIP section,
or publish it in Showcase.

The first screenshot will be displayed as a thumbnail.

xsi3rr4x (36 views)
2014-04-15 18:08:23

BurntPizza (32 views)
2014-04-15 03:46:01

UprightPath (47 views)
2014-04-14 17:39:50

UprightPath (30 views)
2014-04-14 17:35:47

Porlus (47 views)
2014-04-14 15:48:38

tom_mai78101 (68 views)
2014-04-10 04:04:31

BurntPizza (128 views)
2014-04-08 23:06:04

tom_mai78101 (228 views)
2014-04-05 13:34:39

trollwarrior1 (193 views)
2014-04-04 12:06:45

CJLetsGame (200 views)
2014-04-01 02:16:10
List of Learning Resources
by SHC
2014-04-18 03:17:39

List of Learning Resources
by Longarmx
2014-04-08 03:14:44

Good Examples
by matheus23
2014-04-05 13:51:37

Good Examples
by Grunnt
2014-04-03 15:48:46

Good Examples
by Grunnt
2014-04-03 15:48:37

Good Examples
by matheus23
2014-04-01 18:40:51

Good Examples
by matheus23
2014-04-01 18:40:34

Anonymous/Local/Inner class gotchas
by Roquen
2014-03-11 15:22:30
java-gaming.org is not responsible for the content posted by its members, including references to external websites, and other references that may or may not have a relation with our primarily gaming and game production oriented community. inquiries and complaints can be sent via email to the info‑account of the company managing the website of java‑gaming.org
Powered by MySQL Powered by PHP Powered by SMF 1.1.18 | SMF © 2013, Simple Machines | Managed by Enhanced Four Valid XHTML 1.0! Valid CSS!