Thank you very much phi.lho and anchnk.
             
 
              The reason of the applet didn't work is the error:
             
 java.lang.OutOfMemoryError: Java heap space.
              
             
 Just after the browser restart, it works well.
             
 But after reload the applet(push the reload button of the browser), applet never works.
              
             
 I've tryed to write
             
   img[i-33]=loadImage("dummy.png");
             
   for(int j=0;j<width*height;j++) img[i-33].set(j % width, j/width, color(pg.pixels[j]));
             
 but your(anchnk)
             
     img[i-33] = createImage(pg.width, pg.height, RGB);
             
     pg.loadPixels();
             
     img[i-33].loadPixels();
             
     for (int j=0; j<pg.width*pg.height; j++) {
             
       (img[i-33]).pixels[j] = pg.pixels[j];
             
     }
             
     img[i-33].updatePixels();
             
 is better.
              
              
              
             
 The 1st application is as follows.
              
             
 This is based on 
             
 OpenProcessing
              
             
http://www.openprocessing.org/visuals/?visualID=11123
              The improved program dosen't needs lots of character image files.
             
 The four changed points were enclosed by //----n-----.
              
             
 /*
             
 * PushLetters by Christophe Guébert
             
 *  Particle simulation with a grid-based neighbours search.
             
 *  8000 particles and approximately 20k springs.
             
 *  Move the mouse to push the particles around.
             
 *  Space to randomize their position.
             
 *  Press any character or digit key to make a hole.
             
 */
              
             
 final float dt = 1/30.0;
             
 final float dt2 = dt*dt;
             
 final float damping = 0.5;
             
 final float repulsionMaxDist = 5.5;
             
 final float repulsionStiffness = 40;
             
 final float mouseMaxDist = 50;
             
 final float mouseStiffness = 20;
             
 final float particleRadius = 2;
             
 //final float randomAcceleration = 50;
              
             
 final int nbParticles = 8000;
             
 final int gridSize = 5;
              
             
 Particle[] particles;
             
 GridCell[] grid;
             
 boolean letterReset = false;
             
 int gridW, gridH;
             
 final float rmd2 = repulsionMaxDist*repulsionMaxDist;
             
 final float mmd2 = mouseMaxDist*mouseMaxDist;
              
             
 class Particle
             
 {
             
   float x, y, vx, vy, ax, ay, fx, fy;
             
   Particle()
             
   {
             
     x = y = vx = vy = ax = ay = fx = fy = 0.0;
             
     x = random(0, width); y = random(0, height);
             
   }
               
             
   void update() {
             
     x += vx*dt + 0.5*ax*dt2; y += vy*dt + 0.5*ay*dt2;
             
     ax = fx; ay = fy;
             
     vx += 0.5*ax*dt; vy += 0.5*ay*dt;
               
             
     if(x < particleRadius) {
             
       x = 2 * particleRadius - x;
             
       vx = -vx;
             
     } else if(x > width - particleRadius) {
             
       x = 2 * (width - particleRadius) - x;
             
       vx = -vx;
             
     }
             
     if(y < particleRadius) {
             
       y = 2 * particleRadius - y;
             
       vy = -vy;
             
     } else if(y > height - particleRadius) {
             
       y = 2 * (height - particleRadius) - y;
             
       vy = -vy;
             
     }
             
   }
             
 }
               
             
 class GridCell {
             
   boolean tested;
             
   Vector contents;
             
   GridCell() { contents = new Vector(); }
             
 }
              
             
 // -----1-----
             
 PImage[] img=new PImage[94];
             
 PGraphics pg;
             
 // -----1-----
              
             
 void setup() {
             
   size(400, 400, P2D);
             
 // -----2-----
             
   pg=createGraphics(400,400,P2D); 
             
   for(int i=33;i<=126;i++) {//  i=33 '!' , i=126 '~'
             
     pg.beginDraw();
             
     pg.background(0);
             
     pg.fill(255);
             
     pg.textSize(350);
             
     pg.textAlign(CENTER,CENTER);
             
     pg.text((char)i,width/2,height/2);
             
     pg.endDraw();
             
     img[i-33] = createImage(pg.width, pg.height, RGB);
             
     pg.loadPixels();
             
     img[i-33].loadPixels();
             
     for (int j=0; j<pg.width*pg.height; j++) (img[i-33]).pixels[j] = pg.pixels[j];
             
     img[i-33].updatePixels();
             
   }
             
 // -----2-----
              
             
   frameRate(120);  // highest possible
                 
             
   particles = new Particle[nbParticles];
             
   for(int i=0; i<particles.length; i++)
             
     particles[i] = new Particle();
                   
             
   gridW = ceil(width / (float)gridSize);
             
   gridH = ceil(height / (float)gridSize);
             
   grid = new GridCell[gridW * gridH];
             
   for(int i=0; i<grid.length; i++)
             
     grid[i] = new GridCell();
             
   noFill(); stroke(color(255));
             
 }
              
              
             
 void computeSprings() {
             
   for(int i=0; i<grid.length; i++) { // resetting the grid
             
     grid[i].contents.clear();
             
     grid[i].tested = false;
             
   }
              
             
   for(int i=0; i<particles.length; i++)
             
   { // filling the grid with the indexes of the particles
             
     Particle p = particles[i];
             
     grid[floor(p.y)/gridSize*gridW + floor(p.x)/gridSize].contents.add(p);
             
   }
              
             
   for(int y=0; y<gridH; y++) {
             
     for(int x=0; x<gridW; x++)
             
     { // for each cell of the grid
             
       GridCell gc = grid[y*gridW+x];
             
       gc.tested = true;
             
       for(int i=0; i<gc.contents.size(); i++)
             
       { // each particle in that cell
             
         Particle pA = (Particle)gc.contents.get(i);
             
         for(int j=i+1; j<gc.contents.size(); j++)
             
         { // others particles in that cell
             
           // not putting that code in a separate function as it is called a lot
             
           Particle pB = (Particle)gc.contents.get(j);
             
           float dx = pB.x-pA.x; float dy = pB.y-pA.y;
             
           float d = dx*dx+dy*dy;
             
           if(d > rmd2 || d == 0) continue;
             
           d = sqrt(d);
             
           float f = repulsionStiffness * (d - repulsionMaxDist) / d;
             
           pA.fx+=f*dx;  pA.fy+=f*dy; pB.fx-=f*dx;  pB.fy-=f*dy;
             
           pA.fx-=pA.vx*damping; pA.fy-=pA.vy*damping;
             
           pB.fx-=pB.vx*damping; pB.fy-=pB.vy*damping;
             
         }
                         
             
         for(int y2=y; y2<=min(y+1, gridH-1); y2++) //y2=max(0, y-1)
             
         {
             
           for(int x2=max(0, x-1); x2<=min(x+1, gridW-1); x2++)
             
           { // neighbooring cells
             
             GridCell gc2 = grid[y2*gridW+x2];
             
             if(gc2.tested) continue;
             
             for(int j=0; j<gc2.contents.size(); j++)
             
             { // each particle in that cell
             
               // same code as up there, moving it in a function makes me lose 10 fps
             
               Particle pB = (Particle)gc2.contents.get(j);
             
               float dx = pB.x-pA.x; float dy = pB.y-pA.y;
             
               float d = dx*dx+dy*dy;
             
               if(d > rmd2 || d == 0) continue;
             
               d = sqrt(d);
             
               float f = repulsionStiffness * (d - repulsionMaxDist) / d;
             
               pA.fx+=f*dx;  pA.fy+=f*dy; pB.fx-=f*dx;  pB.fy-=f*dy;
             
               pA.fx-=pA.vx*damping; pA.fy-=pA.vy*damping;
             
               pB.fx-=pB.vx*damping; pB.fy-=pB.vy*damping;
             
             }
             
           }
             
         }
             
       }
             
     }
             
   }
             
 }
              
              
             
 void mouseRepulsion()
             
 {  // using the grid even for that !
             
   int xmin = max(0, floor((mouseX - mouseMaxDist) / gridSize));
             
   int xmax = min(gridW, ceil((mouseX + mouseMaxDist) / gridSize));
             
   int ymin = max(0, floor((mouseY - mouseMaxDist) / gridSize));
             
   int ymax = min(gridH, ceil((mouseY + mouseMaxDist) / gridSize));
                 
             
   for(int x=xmin; x<xmax; x++)
             
   {
             
     for(int y=ymin; y<ymax; y++)
             
     {
             
       GridCell gc = grid[y*gridW+x];
             
       for(int i=0; i<gc.contents.size(); i++)
             
       {
             
         Particle p = (Particle)gc.contents.get(i);
             
         float dx = mouseX-p.x; float dy = mouseY-p.y;
             
         float d = dx*dx+dy*dy;
             
         if(d < mmd2)
             
         {
             
           d = sqrt(d);
             
           float f = mouseStiffness * (d - mouseMaxDist) / d;
             
           p.fx += f*dx; p.fy += f*dy;
             
         }
             
       }
             
     }
             
   }
             
 }
              
              
             
 void removeLetter(char c) {
             
 //-----3-----
             
 //  PImage letter = loadImage(""+(int)c+".png");
             
   PImage letter = img[(int)c-33];
             
 //-----3-----
             
   letter.resize(width, height);
             
   letter.loadPixels();
             
   for(int i=0; i<particles.length; i++)
             
   {
             
     Particle p = particles[i];
             
     if(letterReset) { p.x = random(0, width); p.y = random(0, height); }
             
     if((letter.pixels[floor(p.y)*width+floor(p.x)]&0xFF) != 0)
             
     { // If the particle is inside the letter boundaries
             
       // Take a random direction and move the particle
             
       float a = random(0, 2*PI);
             
       float rx = cos(a)*10; float ry = sin(a)*10;
             
       for(int j=0; j<5 && (letter.pixels[floor(p.y)*width+floor(p.x)]&0xFF) != 0; j++) {
             
         p.x = constrain(p.x+rx, 0, width-1); p.y = constrain(p.y+ry, 0, height-1);
             
       }
             
       // If it doesn't work, move it to a complete random position
             
       for(int j=0; j<5 && (letter.pixels[floor(p.y)*width+floor(p.x)]&0xFF) != 0; j++) {
             
         p.x = random(0, width); p.y = random(0, height);
             
       }
             
     }
             
   }
             
 }
              
               
             
 void draw(){
             
   background(color(0));
             
   for(int i=0; i<particles.length; i++)
             
     particles[i].fx = particles[i].fy = 0;
               
             
   long startTime = System.nanoTime();
             
   if(mousePressed || mouseX!=pmouseX || mouseY!=pmouseY)
             
     mouseRepulsion();
             
   computeSprings();
             
   for(int i=0; i<particles.length; i++)
             
     particles[i].update();
               
             
   for(int i=0; i<particles.length; i++)
             
     point(particles[i].x, particles[i].y);
             
 }
              
              
             
 void keyPressed(){
             
   if(key == ENTER)
             
     letterReset = !letterReset;
                 
             
   if(key == ' ') {
             
     for(int i=0; i<particles.length; i++)
             
       particles[i] = new Particle();
             
   }
                 
             
 // -----4-----
             
 //  if( (key >= 'a' && key <= 'z')
             
 //   || (key >= 'A' && key <= 'Z')
             
 //   || (key >= '0' && key <= '9') )
             
   if( key>='!' && key <='~' )
             
 // -----4-----
             
     removeLetter(key);
             
 }
              
              
             
 Thank you.