package demo2;
import java.awt .Color ;
import java.awt .Graphics ;
import java.util .ArrayList ;
import java.util .Iterator ;
import java.util .Random ;
class isortentry {
int type, i, j;
Color c;
String print = null;
public isortentry( int type, int i, Color c) //1 means initial color;
{
this .type = type;
this .i = i;
this .c = c;
if ( this .type == 1 ) {
print = "Checking elements " + i;
} else if ( this .type == 3 )
{
print = "Correct position found..." ;
}
}
public isortentry( int type, int i, int j) //1 means initial color;
{
this .type = type;
this .i = i;
this .j = j;
// this.c = c;
print = "Right shifting... " ;
}
}
public class isortvis extends State {
public UIManager uiManager;
Random r = new Random( 256 ) ;
Color mycolor = new Color( 230 , 92 , 0 ) ;
int i = 2 , ptr = 1 , n = 12 , temp, si, sj, cycle;
visunumber[ ] a = new visunumber[ 25 ] ;
boolean isnew, isswaping;
int pos = 500 ;
ArrayList< isortentry> log = new ArrayList< isortentry> ( ) ;
int list[ ] = new int [ 25 ] ;
int scale;
boolean isrunning;
Iterator itr;
isortentry cur;
public isortvis( Handler handler) {
super( handler) ;
uiManager = new UIManager( handler) ;
isnew = true ;
uiManager.addObject ( new UIImageButton( 800 , 450 , 128 , 48 , Assets.back_bt , new ClickListener( ) {
@Override
public void onClick( ) {
handler.getMouseManager ( ) .setUIManager ( null) ;
handler.getGame ( ) .algomain .init ( 2 ) ;
handler.getMouseManager ( ) .setUIManager ( handler.getGame ( ) .algomain .getUIManager ( ) ) ;
State.setState ( handler.getGame ( ) .algomain ) ;
isnew = true ;
isswaping = false ;
setFps( 10 , 500 ) ;
}
} ) ) ;
uiManager.addObject ( new textclick( 300 , 500 , 40 , 40 , "1" , new ClickListener( ) {
public void onClick( ) {
setFps( 3 , 300 ) ;
}
} ) ) ;
uiManager.addObject ( new textclick( 350 , 500 , 40 , 40 , "2" , new ClickListener( ) {
public void onClick( ) {
setFps( 5 , 350 ) ;
}
} ) ) ;
uiManager.addObject ( new textclick( 400 , 500 , 40 , 40 , "3" , new ClickListener( ) {
public void onClick( ) {
setFps( 7 , 400 ) ;
}
} ) ) ;
uiManager.addObject ( new textclick( 450 , 500 , 40 , 40 , "4" , new ClickListener( ) {
public void onClick( ) {
setFps( 9 , 450 ) ;
}
} ) ) ;
uiManager.addObject ( new textclick( 500 , 500 , 40 , 40 , "5" , new ClickListener( ) {
public void onClick( ) {
setFps( 10 , 500 ) ;
}
} ) ) ;
}
private void swap( visunumber a[ ] , int in, int jn) {
visunumber temp = a[ in] ;
a[ in] = a[ jn] ;
a[ jn] = temp;
}
private void swapt( int a[ ] , int in, int jn) {
int temp = a[ in] ;
a[ in] = a[ jn] ;
a[ jn] = temp;
}
void insertionSort( ) {
int i, key, j;
for ( i = 1 ; i < n; i++ ) {
key = list[ i] ;
log .add ( new isortentry( 1 , i, Color.RED ) ) ;
j = i - 1 ;
while ( j > 0 && list[ j] > key) {
list[ j + 1 ] = list[ j] ;
log .add ( new isortentry( 2 , j, j+ 1 ) ) ;
j = j - 1 ;
}
list[ j + 1 ] = key;
log .add ( new isortentry( 3 , j+ 1 , Color.white ) ) ;
}
}
public void init( ) {
n = 15 ;
for ( int k = 0 ; k <= 15 ; k++ ) {
int rand = 5 + r.nextInt ( 35 ) ;
a[ k] = new visunumber( rand , mycolor, 400 , 300 - rand * 5 , rand * 5 , 30 ) ;
// ori[k] = a[k];
list[ k] = rand ;
}
list[ 0 ] = - 1 ;
insertionSort( ) ;
isswaping = false ;
i = 0 ;
itr = log .iterator ( ) ;
isrunning = true ;
setFps( 2 , 350 ) ;
scale = 0 ;
isswaping = false ;
// play = true;
}
@Override
public void tick( ) {
uiManager.tick ( ) ;
if ( ! isswaping) {
if ( isrunning && scale == 0 ) {
if ( itr.hasNext ( ) ) {
cur = ( isortentry) itr.next ( ) ;
} else {
for ( int i = 0 ; i < n; i++ ) {
a[ i] .setColor ( Color.white ) ;
isrunning = false ;
}
}
if ( cur ! = null) {
// cp = cur.print;
}
scale = 1 ;
} else {
scale-- ;
}
}
}
@Override
public void render( Graphics g) {
g.drawImage ( Assets.blankbg , 0 , 0 , null) ;
g.setColor ( Color.white ) ;
g.setFont ( Assets.title ) ;
g.drawString ( "I Sort" , 300 , 40 ) ;
g.setColor ( Color.white ) ;
g.setFont ( Assets.consolett ) ;
g.drawString ( "Speed: " , 220 , 520 ) ;
g.drawString ( "^" , pos + 10 , 500 ) ;
uiManager.render ( g) ;
if ( ! isswaping) {
if ( cur ! = null) {
if ( cur.type == 1 ) {
a[ cur.i ] .setY ( a[ cur.i ] .y + a[ cur.i ] .h ) ;
a[ cur.i ] .setColor ( Color.red ) ;
} else if ( cur.type == 2 )
{
swap( a, cur.i , cur.j ) ;
}
else if ( cur.type == 3 )
{
a[ cur.i ] .setY ( a[ cur.i ] .y - a[ cur.i ] .h ) ;
a[ cur.i ] .setColor ( Color.white ) ;
}
}
cur = null;
}
for ( int i = 1 ; i < n; i++ ) {
a[ i] .drawbox ( g, i) ;
}
}
@Override
public UIManager getUIManager( ) {
return uiManager;
}
@Override
public void init( int i) {
throw new UnsupportedOperationException( "Not supported yet." ) ; //To change body of generated methods, choose Tools | Templates.
}
public void setFps( int n, int i) {
pos = i;
handler.getGame ( ) .setFps ( n) ;
}
}
package demo2;
 
import java.awt.Color;
import java.awt.Graphics;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.Random;
 
class isortentry {
 
    int type, i, j;
    Color c;
    String print = null;
 
    public isortentry(int type, int i, Color c)//1 means initial color;
    {
        this.type = type;
        this.i = i;
        this.c = c;
        if (this.type == 1) {
            print = "Checking elements " + i;
        } else if(this.type==3)
        {
            print = "Correct position found...";
        }
        
    }
 
    public isortentry(int type, int i, int j)//1 means initial color;
    {
        this.type = type;
        this.i = i;
        this.j = j;
       // this.c = c;
        print = "Right shifting... ";
    }
 
}
 
 
public class isortvis extends State {
 
    public UIManager uiManager;
    Random r = new Random(256);
    Color mycolor = new Color(230, 92, 0);
    int i = 2, ptr = 1, n = 12, temp, si, sj, cycle;
    visunumber[] a = new visunumber[25];
    boolean isnew, isswaping;
    int pos = 500;
 
 
    ArrayList<isortentry> log = new ArrayList<isortentry>();
    int list[] = new int[25];
    int scale;
    boolean isrunning;
    Iterator itr;
    isortentry cur;
 
    public isortvis(Handler handler) {
        super(handler);
        uiManager = new UIManager(handler);
        isnew = true;
        uiManager.addObject(new UIImageButton(800, 450, 128, 48, Assets.back_bt, new ClickListener() {
            @Override
            public void onClick() {
                handler.getMouseManager().setUIManager(null);
                handler.getGame().algomain.init(2);
                handler.getMouseManager().setUIManager(handler.getGame().algomain.getUIManager());
                State.setState(handler.getGame().algomain);
                isnew = true;
                isswaping = false;
                setFps(10, 500);
            }
        }));
 
        uiManager.addObject(new textclick(300, 500, 40, 40, "1", new ClickListener() {
            public void onClick() {
                setFps(3, 300);
            }
        }));
        uiManager.addObject(new textclick(350, 500, 40, 40, "2", new ClickListener() {
            public void onClick() {
                setFps(5, 350);
            }
        }));
        uiManager.addObject(new textclick(400, 500, 40, 40, "3", new ClickListener() {
            public void onClick() {
                setFps(7, 400);
            }
        }));
        uiManager.addObject(new textclick(450, 500, 40, 40, "4", new ClickListener() {
            public void onClick() {
                setFps(9, 450);
            }
        }));
        uiManager.addObject(new textclick(500, 500, 40, 40, "5", new ClickListener() {
            public void onClick() {
                setFps(10, 500);
            }
        }));
    }
 
    private void swap(visunumber a[], int in, int jn) {
        visunumber temp = a[in];
        a[in] = a[jn];
        a[jn] = temp;
 
    }
 
 
    private void swapt(int a[], int in, int jn) {
        int temp = a[in];
        a[in] = a[jn];
        a[jn] = temp;
 
    }
 
    void insertionSort() {
        int i, key, j;
        for (i = 1; i < n; i++) {
            key = list[i];
            log.add(new isortentry(1, i, Color.RED));
            j = i - 1;
            while (j > 0 && list[j] > key) {
                list[j + 1] = list[j];
                log.add(new isortentry(2, j, j+1));
                j = j - 1;
            }
            list[j + 1] = key;
            log.add(new isortentry(3, j+1, Color.white));
        }
    }
 

    public void init() {
         n = 15;
        for (int k = 0; k <=15; k++) {
            int rand = 5 + r.nextInt(35);
            a[k] = new visunumber(rand, mycolor, 400, 300 - rand * 5, rand * 5, 30);
           // ori[k] = a[k];
            list[k] = rand;
        }
        list[0]=-1;
        insertionSort();
        isswaping = false;
        i = 0;
       
        itr = log.iterator();
        isrunning = true;
        setFps(2, 350);
        scale = 0;
        isswaping = false;
       // play = true;
 
    }
 
    @Override
    public void tick() {
 
        uiManager.tick();
        if (!isswaping) {
                if (isrunning && scale == 0) {
                    if (itr.hasNext()) {
                        cur = (isortentry) itr.next();
                    } else {
                        for (int i = 0; i < n; i++) {
                            a[i].setColor(Color.white);
                            isrunning = false;
                        }
                    }
                    if (cur != null) {
                       // cp = cur.print;
                    }
                    scale = 1;
                } else {
                    scale--;
                }
            }
 
    }
 
    @Override
    public void render(Graphics g) {
        g.drawImage(Assets.blankbg, 0, 0, null);
 
        g.setColor(Color.white);
        g.setFont(Assets.title);
        g.drawString("I Sort", 300, 40);
 
        g.setColor(Color.white);
        g.setFont(Assets.consolett);
        g.drawString("Speed: ", 220, 520);
        g.drawString("^", pos + 10, 500);
        uiManager.render(g);
 
 
        if (!isswaping) {
            if (cur != null) {
                if (cur.type == 1) {
                    a[cur.i].setY(a[cur.i].y +a[cur.i].h);
                    a[cur.i].setColor(Color.red);
                } else if(cur.type==2)
                {
                    swap(a, cur.i, cur.j);
                }
                else if(cur.type==3)
                {
                    a[cur.i].setY(a[cur.i].y - a[cur.i].h);
                    a[cur.i].setColor(Color.white);
                }
            }
            cur = null;
        }
 
            for (int i = 1; i < n; i++) {
                a[i].drawbox(g, i);
 
    }
    }
    @Override
    public UIManager getUIManager() {
        return uiManager;
    }
 
    @Override
    public void init(int i) {
        throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
    }
 
    public void setFps(int n, int i) {
        pos = i;
        handler.getGame().setFps(n);
    }
}