Results 1 to 4 of 4

Thread: Procedural Noise

  1. #1

    Procedural Noise

    It is very useful to have an efficient noise generator for creating textures and height maps. You can feed an ordered series of numbers (eg 1,2,3,4) to the noise function and be sure to get a chaotic but entirely deterministic series in return. Unlike a RND function, the noise function has no memory of its previous seeded state.

    I found this one works well:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    '----------------------------
    Function Noiseb(sys i) As sys
    '============================
    mov eax,i
    xor eax,35353535
    imul eax,eax
    ror eax,17
    imul eax,eax
    ror eax,7
    and eax,255 'byte mask
    mov _return,eax
    End Function
    Here is a demo using Oxygen and TBGL

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    ' Oxygen Texture generation with procedural noise
    ' Charles Pegge 2010
    '
    ' Using example of rendering colored, lighted and textured shape with GBuffers
    ' Petr Schreiber, 2010
     
     
    Uses "TBGL", "Oxygen"
     
    Begin Const
      %tBricks = 1
    End Const
     
    Function TBMAIN()
      Local i,j,k     As Long
      Local hWnd      As DWord
      Local FrameRate As Double
       
      ' -- Create and show window
      hWnd = TBGL_CreateWindowEx("GBuffers: textured shape press ESC to quit", 640, 480, 32, %TBGL_WS_WINDOWED Or %TBGL_WS_CLOSEBOX)
      TBGL_ShowWindow  
       
      TBGL_BackColor 255,255,255,255
       
      ' -- Load texture
      'TBGL_LoadTexture APP_SourcePath+"bricks.bmp", %tBricks, %TBGL_TEX_MIPMAP
       
     
       
       
      '=======
      'TEXTURE
      '=======  
       
      Dim Texture(65536*4) As tbgl_tRGBA
      '
      '----------------------------------------
      'OXYGEN COMPILE & EXEC TEXTURE GENERATION
      '----------------------------------------
      '
      dim src as string
      src="
      basic
     
      '------------------------------
      Function Noise(sys i) As Single
      '==============================
      Static As Single f, d=1/0x7fffffff
      mov eax,i
      xor eax,35353535
      imul eax,eax
      ror eax,17
      imul eax,eax
      ror eax,7
      push eax
      fild dWord [esp]
      add esp,4
      fmul dWord d
      fstp dWord _return
      End Function
     
      '----------------------------
      Function Noiseb(sys i) As sys
      '============================
      mov eax,i
      xor eax,35353535
      imul eax,eax
      ror eax,17
      imul eax,eax
      ror eax,7
      and eax,255 'byte mask
      mov _return,eax
      End Function
     
     
      type rgba  r as byte, g as byte, b as byte, a as byte
      dim axrng,x,y,r,sc,stp as double
      dim px,py,p as long
      dim n as long
      dim v as long 'byte
      dim as rgba  tex at p : p=#texture 'LINK TO THINBASIC Texture()
      axrng=10 : sc=255 : stp=0.04
      y=-axrng
     
     
      for py=1 to 512
        x=-axrng
        for px=1 to 512
          v=noiseb(n)
          tex.r=v
          tex.g=v
          tex.b=v
          n+=1
          p+=sizeof tex 'ADVANCE TEXTURE ARRAY POINTER
        Next
        'y+=stp
      Next
      "
      '
      'msgbox 0,o2_prep src
      o2_asmo src
      if len(o2_error) then
        msgbox 0,o2_error
        stop
      else
        o2_exec
      end if
      '
       
      Local TexString As String = Peek$(VarPtr(Texture(1)), 65536*4*SizeOf(tbgl_tRGBA))
       
       
       
      ' Making BMP file from TexString variable, size 512*512, to slot #2 with 16x anisotropic filtering
      TBGL_MakeTexture TexString, %TBGL_DATA_RGBA, 512, 512, 2, %TBGL_TEX_ANISO, 16
     
      ' -- Create 3D triangle buffer
      Dim gbQuad As DWord = TBGL_GBufferCreate(%TBGL_Quads, %TBGL_3D)
       
      ' -- Define data for it
      Dim VertexA(4)    As TBGL_tVector3F
      Dim ColorA(4)     As TBGL_tRGBA  
      Dim NormalA(4)    As TBGL_tVector3F  
      Dim TexCoordA(4)  As TBGL_tVector2F
       
      ' -- Vertices
      VertexA(1).x = -1
      VertexA(1).y = -1
      VertexA(1).z =  0
       
      VertexA(2).x =  1
      VertexA(2).y = -1    
      VertexA(2).z =  0 
       
      VertexA(3).x =  1
      VertexA(3).y =  1
      VertexA(3).z =  0 
     
      VertexA(4).x = -1
      VertexA(4).y =  1
      VertexA(4).z =  0 
       
      ' -- Normals
      For i = 1 To 4
        NormalA(i).x = 0
        NormalA(i).y = 0
        NormalA(i).z = 1
      Next  
       
      ' -- Colors
      '
      for i=1 to 4
        ColorA(i).r = 255
        ColorA(i).g = 255
        ColorA(i).b = 255     
        ColorA(i).a = 255
      next
      '
      ' -- Texture coordinates
      For i = 1 To 4
        TexCoordA(i).x = VertexA(i).x
        TexCoordA(i).y = VertexA(i).y
      Next 
       
      ' -- Create buffer dynamically linked to the arrays above
      TBGL_GBufferDefineFromArray(gbQuad, %TBGL_Dynamic, 4, VertexA(1), ColorA(1), NormalA(1), TexCoordA(1))
             
      TBGL_UseLighting(%TRUE)
      TBGL_UseLightSource(%GL_LIGHT0, %TRUE)               
             
      TBGL_UseTexturing(%TRUE)
      TBGL_BindTexture(2) 
       
      'TBGL_UseAlphaTest(%TRUE)   
      'TBGL_AlphaFunc(%TBGL_GREATER, 0.1)
      TBGL_BlendFunc(%GL_DST_ALPHA, %GL_SRC_ALPHA)
      TBGL_UseBlend(%TRUE)        
       
      ' -- Resets status of all keys
      TBGL_ResetKeyState()
     
      ' -- Main loop
      While TBGL_IsWindow(hWnd)
        FrameRate = TBGL_GetFrameRate
     
        TBGL_ClearFrame
        TBGL_Camera(0, 0, 5, 0, 0, 0)
     
        tbgl_pushmatrix
        tbgl_translate 0,0,-1
        tbgl_scale 2,2,1     
        tbgl_GBufferRender(gbQuad)
        tbgl_popmatrix
     
     
          ' -- Turn
          'TBGL_Rotate GetTickCount/100, 1, 0, 0
          'TBGL_Rotate GetTickCount/105, 0, 1, 0
          TBGL_Rotate GetTickCount/60, 0, 0, 1
                                   
          ' -- Modify Texture coordinates
          '
          For i = 1 To 4
            TexCoordA(i).x = VertexA(i).x*(Sin(GetTickCount/400)*.25+.75)
            TexCoordA(i).y = VertexA(i).y*(cos(GetTickCount/500)*.25+.75)
          Next
       
     
          ' -- Render it
          '                            
          tbgl_GBufferRender(gbQuad)          
     
        TBGL_DrawFrame
     
        ' -- ESCAPE key to exit application
        If TBGL_GetWindowKeyState(hWnd, %VK_ESCAPE) Then Exit While
     
      Wend        
      ' -- Destroying the buffer is not necessary,
      ' -- the garbage collector will take care of it
     
      ' -- Destroy window
      TBGL_DestroyWindow
    End Function
    If you have problems running this code - the latest Oxygen is available here:

    http://www.thinbasic.com/community/s...iler-Downloads

    Charles

  2. #2
    Super Moderator Petr Schreiber's Avatar
    Join Date
    Aug 2005
    Location
    Brno - Czech Republic
    Posts
    7,156
    Rep Power
    736
    Thanks a lot Charles!

    After updating Oxygen it worked great here.
    The noise generation was very fast, there is no noticeable lag on loading.


    Petr
    Learn 3D graphics with ThinBASIC, learn TBGL!
    Windows 10 64bit - Intel Core i5-3350P @ 3.1GHz - 16 GB RAM - NVIDIA GeForce GTX 1050 Ti 4GB

  3. #3
    Senior Member Lionheart008's Avatar
    Join Date
    Sep 2008
    Location
    Germany, Bad Sooden-Allendorf
    Age
    52
    Posts
    944
    Rep Power
    111
    thanks charles for this nice noise effects that works here with new oxygen update my question: what's the sense of dimension
    65536*4
    in
    Dim Texture(65536*4) As tbgl_tRGBA
    ?
    I have changed a little the example with another noise effect. I think it's also possible to texture a usual quad cube too, isn't it? nice evening, thanks, frank
    Attached Images Attached Images
    Attached Files Attached Files
    Last edited by Lionheart008; 16-12-2010 at 21:15.
    you can't always get what you want, but if you try sometimes you might find, you get what you need

  4. #4
    Many thanks for testing guys.

    Since I last produced any examples here, there have been 23 alpha releases. So I could not be sure this would work with an older Oxygen.

    To clarify the texture dimensioning: 65536*4 looks a lot better in hexadecimal: &h40000. The noise function is iterated through &h200 x &h200 dwords (RGBA)

    You can wrap this texture around any surface from cubes to terrains.

    Slight changes to the noise function will yield complex repeating patterns rather than chaos. - something to explore.

    Charles

Similar Threads

  1. reducing the noise from the wall
    By zak in forum Shout Box Area
    Replies: 4
    Last Post: 05-08-2011, 21:35
  2. Procedural generation of city
    By Petr Schreiber in forum Technology
    Replies: 3
    Last Post: 17-05-2009, 09:49

Members who have read this thread: 0

There are no members to list at the moment.

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts
  •