Noise:setFractalOctaves(n): Default: 3 The amount of noise layers used to create the fractal Used in all fractal noise generation
Noise:getFractalOctaves() returns number of fractal octaves
Noise:setInterp(interpolation): Default: Noise.QUINTIC Changes the interpolation method used to smooth between noise values Used in Value and Perlin Noise Possible interpolation methods (lowest to highest quality):
Noise:setCellularDistanceFunction(distanceFunctionType): Default: Noise.EUCLIDEAN The distance function used to calculate the cell for a given point Possible distance functions:
Noise.EUCLIDEAN
Noise.MANHATTAN
Noise.NATURAL
Natural is a blend of Euclidean and Manhattan to give curved cell boundaries
Noise:getCellularDistanceFunction() returns distance function type (number [EUCLIDEAN = 0, MANHATTAN = 1, NATURAL = 2])
Noise:setCellularReturnType(returnType): Default: Noise.CELL_VALUE What value does the cellular function return from its calculations Possible return types:
Noise.CELL_VALUE
Noise.NOISE_LOOKUP
Noise.DISTANCE
Noise.DISTANCE_2
Noise.DISTANCE_2_ADD
Noise.DISTANCE_2_SUB
Noise.DISTANCE_2_MUL
Noise.DISTANCE_2_DIV
Only CellValue is bounded between -1.0 and 1.0, all distance return types have a minimum of 0 and varying maximums NoiseLookup requires another Noise object be set with setCellularNoiseLookup() to function
Noise:setCellularNoiseLookup(Noise): Noise used to calculate a cell value if cellular return type is NoiseLookup The lookup value is acquired through GetNoise() so ensure you SetNoiseType() on the noise lookup, value, perlin or simplex is recommended.
Noise:getCellularNoiseLookup() returns Noise object that was set by setCellularNoiseLookup() function
Noise:setCellularDistance2Indices(index0, index1): Default: 0, 1 Sets the 2 distance indicies used for distance2 return types Note: index0 should be lower than index1 Both indicies must be >= 0, index1 must be < 4
Noise:setCellularJitter(jitter): Default: 0.45 Sets the maximum distance a cellular point can move from its grid position Note: Setting this high will make cellular grid artifacts more common
Noise:getCellularJitter() returns cellular jitter value
Noise:setGradientPerturbAmp(amp): Default: 1.0 Sets the maximum perturb distance from original location when using gradientPerturb()
You can’t use vs to compile plugins for gideros without a lot of trouble. You need to use qt compiler for windows and similarly the same tools gideros are compiled with
@antix ok, I have added 1D noise. @hgy29 well, I've spent all day trying to get VS to work, but no success I have compiled lua (5.1) from sources, but again, same error.
You need to write a project file for qt, .pro, take a look at other plugins. Then use qmake and make to build it (or qtcreator). There is a guide on the wiki, named how to build gideros from sources or something like that. It covers both main gideros and plugins iirc.
Hmm, seems like I missed something, because, my libs looks like: LIBS += -L"../../../Sdk/lib/desktop" -llua And I thought that it is the same as in clipper.pro, but it turns out that I have copied bitop libs path)))) so I guess I just need to add -lgid to make it work
Back to VS In order to link gid.dll in VS I need *.lib and *.dll files, there is no *.lib files in gideros folder (apart from \Gideros\All Plugins\steam\source\vs but it only contatin *.lib without *.dll), so I assume that I need to get it by myself. The question is - how?) There is a tutorial of how to build gideros from surces but seems like I will only get dll's. Any tips?)
P.S. If you planning to release new version of gideros during this week, please let me know, I also want to add this binding with this release
Trying to get it to work with gideros class system, but before making it public, I need some tests, if you interested, please take some time and do some tests, thanks!
Back to VS In order to link gid.dll in VS I need *.lib and *.dll files, there is no *.lib files in gideros folder (apart from \Gideros\All Plugins\steam\source\vs but it only contatin *.lib without *.dll), so I assume that I need to get it by myself. The question is - how?) There is a tutorial of how to build gideros from surces but seems like I will only get dll's. Any tips?)
Yes, VS needs import libraries to link against DLL, while gcc/mingw (backend for Gideros QT) doesn't (or generates .a files instead). I had to make one for steam plugin, kind of hand made using a function listing (the .def file) and the implib tool from VS tools. I followed a tutorial on the internet to do that.
But you may face various issues if you want to use VS, in particular with C++: different compilers may organize C++ internal machinery differently, so interopertaing C++ code from different compilers may not work as expected. For steam the API was pretty much 'C' only between gideros and the plugin.
Anyway, sincere congratulations for your first plugin!
Yes, VS needs import libraries to link against DLL, while gcc/mingw (backend for Gideros QT) doesn't (or generates .a files instead). I had to make one for steam plugin, kind of hand made using a function listing (the .def file) and the implib tool from VS tools. I followed a tutorial on the internet to do that.
But you may face various issues if you want to use VS, in particular with C++: different compilers may organize C++ internal machinery differently, so interopertaing C++ code from different compilers may not work as expected. For steam the API was pretty much 'C' only between gideros and the plugin.
It is a little bit more complex than I thought In this case I'll use QT.
Maybe some Gideros specific additions would be nice for this plugin: - being able to generate a full array of noise values in a single call - being able to make a texture from them, either greyscale or color if supplying a gradient pattern
Doing draw calls is a plugin requires a lot of work and in-depth understanding of how gideros works internally. I was thinking of being able to call texture creation routines directly (gtexture_xxx API), or through lua: you generate the 'data' string for Texture.new(data,...) call in C, then call Texture.new with it from C code. I can add it if you wish once the plugin is over.
Yes, that is exactly what I meant. For args, the data is a string containing R,G,B,A values (one byte per channel) for each pixel, so a 4xWidthxHeight char array in C, then you'll just need to:
/ generate data for texture
lua_getglobal(L,"Texture")
lua_getfield(L,-1,"new")
lua_pushlstring(L,data,4*width*height);
lua_pushinteger(L,width);
lua_pushinteger(L,height);
lua_pushboolean(L,filtering);
lua_call(L,4,1);// Newly created texture is on stack already, just return itreturn1;
I have finished with binding. But stacked with that texture data generation Since Im not a C/C++ programmer I need to learn how to work with char/unsigned char data types.
In lua, its easy
local str =""function byteColor(r,g,b,a)returnstring.char(r)..string.char(g)..string.char(b)..string.char(a)endlocal w, h =10,10local clr = byteColor(255,0,0,255)for i =1, w*h do
str = str .. clr
endlocal t = Texture.new(str, w, h)local btm = Bitmap.new(t)
btm:setScale(50)
stage:addChild(btm)
EDIT: Hmm...why gideros Texture/RenderTarget dont have some sort of "loadPixels" function... It would be useful for realtime texture generation. Instead of creating new texture every time, we create pixel data for existing one.
//Color values are unsigned char (0-255)//Allocate an arrayunsignedchar*data=new unsignedchar[w*h*4];unsignedchar*ptr=data;//Fill it with noisefor(int i=0;i<(w*h);i++){float noise=getNoise(...);//Convert [-1,1] into [0,255]unsignedchar lum=(unsignedchar)((noise+1)*255/2);*ptr++=lum;//R*ptr++=lum;//G*ptr++=lum;//B*ptr++=255;//A}// Use our data array, eg: lua_pushlstring(L,(char *)data,w*h*4);//Delete our data array
delete data;
Comments
Likes: rrraptor
Likes: rrraptor
P.S. Playing around
Likes: Apollo14, MoKaLux
Oh, does your library make fast 1D noise also? That's very handy for 2D games
From readme:
@hgy29 well, I've spent all day trying to get VS to work, but no success I have compiled lua (5.1) from sources, but again, same error. Is there any tutorial of how to build plugins with qt... I dont even know where to start. I installed qt-opensource-windows-x86-5.10.1 from http://master.qt.io/archive/qt/5.10/5.10.1/qt-opensource-windows-x86-5.10.1.exe
But what now?)
Likes: MoKaLux
Likes: MoKaLux
But, I cant open it?
EDIT:
Never mind! I've successfully compiled sample plugin, but my code from 1st post still does not work! Same errors...
But clipper plugin compiles correctly. wtf is going on here...?
LIBS += -L"../../../Sdk/lib/desktop" -llua
And I thought that it is the same as in clipper.pro, but it turns out that I have copied bitop libs path))))
so I guess I just need to add -lgid to make it work
Back to VS In order to link gid.dll in VS I need *.lib and *.dll files, there is no *.lib files in gideros folder (apart from \Gideros\All Plugins\steam\source\vs but it only contatin *.lib without *.dll), so I assume that I need to get it by myself. The question is - how?)
There is a tutorial of how to build gideros from surces but seems like I will only get dll's. Any tips?)
P.S. If you planning to release new version of gideros during this week, please let me know, I also want to add this binding with this release
EDIT:
QT build works
Likes: Apollo14, hgy29, SinisterSoft, MoKaLux
@antix can you test 1D noise?)
I've attached a plugin. Put it into "Plugins" folder inside you Gideros installation folder.
WORKS ONLY FOR WINDOWS
API can be found here: https://github.com/Auburns/FastNoise/wikiBut it is a little bit different.
For noise functions use FNoise.Noise1D(x) or FNoise.Noise2D(x, y) or FNoise.Noise3D(x, y, z)
For interpolation method (SetInterp) values are:
Binding for 4D WhiteNoise (WhiteNoiseInt) and 4D SimplexNoise is not implemented (sorry, I forgot about these).
Quick "HowTo":
But you may face various issues if you want to use VS, in particular with C++: different compilers may organize C++ internal machinery differently, so interopertaing C++ code from different compilers may not work as expected. For steam the API was pretty much 'C' only between gideros and the plugin.
Anyway, sincere congratulations for your first plugin!
Likes: MoKaLux
Likes: MoKaLux
- being able to generate a full array of noise values in a single call
- being able to make a texture from them, either greyscale or color if supplying a gradient pattern
I've found this in Box2D plugin:
For args, the data is a string containing R,G,B,A values (one byte per channel) for each pixel, so a 4xWidthxHeight char array in C, then you'll just need to:
Likes: rrraptor, SinisterSoft
Likes: rrraptor
In lua, its easy
Hmm...why gideros Texture/RenderTarget dont have some sort of "loadPixels" function... It would be useful for realtime texture generation. Instead of creating new texture every time, we create pixel data for existing one.
Likes: rrraptor
The interface looks like that:
filtering (boolean, default - false) indicate that the texture should be filtered [optional]
noiseScale (number, default - 1) noise scale factor [optional]
noiseZOffset (number, default - 0) noise z scroll [optional]
1024x1024 texture generates in 0.3 seconds (i7-2600k).
In realtime generating 256x256 texture EVERY frame drops fps to 40+ (classic Perlin noise)
256x256 using simplex noise gives stable 60 fps
Likes: MoKaLux
A bit of profiling:
Number of tests: 10000000
test1 6.0592579999998
test2 1.9603821000005
Number of tests: 1
test3 0.041751500000146
test4 0.13199930000019
test5 0.49677059999999
test6 1.9523522999998
Test1: generate noise array from lua (len - 1000000)
Test2: generate noise array from C (same len)
Test3: generate single 128x128 texture
Test4: generate single 256x256 texture
Test5: generate single 512x512 texture
Test6: generate single 1024x1024 texture
Likes: antix, MoKaLux
https://play.google.com/store/apps/developer?id=razorback456
мій блог по гідерос https://simartinfo.blogspot.com
Слава Україні!
Likes: oleg, MoKaLux
https://github.com/MultiPain/Gideros_FastNoise_binding
I've uploaded sources.
Im absolutely not sure about this original methods:
Also, 1D noise still broken, idk how to fix it. I think I'll just add Perlin and simplex noises for it, without fractals and other stuff.