//NewGuideOutputPanel.java
import java.awt.*;
import java.awt.event.*;
import java.awt.image.BufferedImage;
import java.io.IOException;
import javax.imageio.ImageIO;

public class NewGuideOutputPanel extends Panel implements ItemListener{
	NewGuide_State state;
	NewGuideCanvas rcanvas;
	private static final Color bgcolor = new Color(236,236,221);
	
        private Font labfont=new Font("SanSerif",Font.PLAIN,12);
	private Font titlefont=new Font("SanSerif",Font.BOLD,16);
	private Font symbolfont=new Font("Symbol",Font.PLAIN,12);
	
	Label titlelabel;	
	public Choice c1;
	
	public NewOutputCanvasA rwocA; 
	public NewOutputCanvasB rwocB; 
	public NewOutputCanvasField rwocField; 
	
	public NewGuideOutputPanel(NewGuide_State state, NewGuideCanvas rcanvas){
	    super();
	    setLayout(null);
	    this.state = state;
	    this.rcanvas = rcanvas;
	    
            labfont = new Font("SanSerif",Font.PLAIN,state.font12);
            titlefont = new Font("SanSerif",Font.BOLD,state.font16);
            symbolfont = new Font("Symbol",Font.PLAIN,state.font12);
            
            setBackground(bgcolor);
            
	    titlelabel = new Label("Data",Label.LEFT);
	    add(titlelabel);
	    titlelabel.setBounds(state.s20,state.s10,state.s100,state.s20);    
	    titlelabel.setFont(titlefont);
	    
	    c1 = new Choice();
	    c1.addItem(" Antenna Data ");
	    c1.addItem(" Field Scanner ");
	    c1.addItem(" Discretization ");
	    //add(c1);
	    c1.setBounds(state.s155,state.s8,state.s110,state.s15);
	    c1.setBackground(bgcolor.brighter());
	    	 
	    Panel ps1 = new Panel();
	    ps1.setBackground(Color.cyan);
	    //add(ps1);
	    ps1.setBounds(state.s153,state.s4,state.s104,state.s24);
	    
	    Panel ps2 = new Panel();
	    ps2.setBackground(Color.black);
	    //add(ps2);
	    ps2.setBounds(state.s152,state.s3,state.s106,state.s26);
	    
	    rwocA = new NewOutputCanvasA(state);
	    //pane1.add(rwocA);
	    add(rwocA);
	    rwocA.setBounds(state.s5,state.s30,state.s200+state.s85,state.s200+state.s52);
	    
	    rwocB = new NewOutputCanvasB(state);
	    //pane2.add(rwocB);
	    add(rwocB);
	    rwocB.setBounds(state.s5,state.s30,state.s200+state.s85,state.s200+state.s52);
	    
	    rwocField = new NewOutputCanvasField(state,rcanvas);
	    //pane3.add(rwocField);
	    add(rwocField);
	    rwocField.setBounds(state.s5,state.s30,state.s200+state.s85,state.s200+state.s57);
	    
	    rwocA.setVisible(true);
	    rwocB.setVisible(false);
	    rwocField.setVisible(false);
	    
	    //Listeners
	    c1.addItemListener(this);
	    state.ignition();
	}
	
    public void paint(Graphics g){
	
	g.setColor(bgcolor.darker());
	g.fillRect(0,getSize().height-2,getSize().width,2);
	g.fillRect(getSize().width-2,0,2,getSize().height);
	g.setColor(bgcolor.brighter());
	g.fillRect(0,0,2,getSize().height-1);
	g.fillRect(0,0,getSize().width-2,2);
	
    }

    public void itemStateChanged(ItemEvent evt){
	ItemSelectable ie = evt.getItemSelectable();
	    if(evt.getSource()==c1){
		if(ie.getSelectedObjects()[0]==" Antenna Data "){
		    rwocA.setVisible(true);
		    rwocB.setVisible(false);
		    rwocField.setVisible(false);
		    //pane1.setVisible(true);
		    //pane2.setVisible(false);
		    //pane3.setVisible(false);
		}
		else if(ie.getSelectedObjects()[0]==" Discretization "){
		    rwocA.setVisible(false);
		    rwocB.setVisible(true);
		    rwocField.setVisible(false);
		    //pane1.setVisible(false);
		    //pane2.setVisible(true);
		    //pane3.setVisible(false);
		}
		else if(ie.getSelectedObjects()[0]==" Field Scanner "){
		    rwocA.setVisible(false);
		    rwocB.setVisible(false);
		    rwocField.setVisible(true);
		    //pane1.setVisible(false);
		    //pane2.setVisible(false);
		    //pane3.setVisible(true);
		}
	    }
    }	
}

class NewOutputCanvasA extends Canvas{
	private Font normalfont = new Font("SanSerif",Font.PLAIN,12);
	private Font subfont    = new Font("SanSerif",Font.PLAIN,10);
	private Font symbolfont=new Font("Serif",Font.PLAIN,12);
	
        public String string_field, unit_field; 
	int x, y;
	public Complex field;
	public double fieldfar;
	NewGuide_State state;
	private Image im;
	private Graphics buf;
	public NewOutputCanvasA(NewGuide_State state){
	    super();
	    this.state = state;
	    
	}
	
	public void paint(Graphics g){
	    if(im == null){
		im = createImage(getSize().width,getSize().height);
		buf = im.getGraphics();
		drawCanvas(buf);
	    }
	    else{
		drawCanvas(buf);
	    }
	    g.drawImage(im,0,0,null);
	}

	//Addition to reduce flicker new routine
	public void update(Graphics g){		// added to avoid clearing
	    paint(g);
	}
	
	public void clear(){
	    this.getGraphics().clearRect(0,0,getSize().width,getSize().height);
	    repaint();
	}

	public void drawCanvas(Graphics g){
            normalfont = new Font("SanSerif",Font.PLAIN,state.font12);
            subfont = new Font("SanSerif",Font.PLAIN,state.font10);
            symbolfont = new Font("Serif",Font.PLAIN,state.font12);
            
            Graphics2D g2d = (Graphics2D)g;
            g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING,RenderingHints.VALUE_ANTIALIAS_ON);
	    int x, y, dx, dxx, dy, dyy;
	    double tempcap, Cond1, Res1, tempind, f_normalized;
	    Color bgcolor = new Color(236,236,221);
	    String stmp;
	    FontMetrics fm;
	    
	    double light_velocity = 1.0/Math.sqrt(state.epsilon0*state.mu0*state.epsilon_r);
	    double light_velocity0 = 1.0/Math.sqrt(state.epsilon0*state.mu0);
	    String lambda, Ohm, infinity;
	    
            x = state.s10;
	    y = state.s25;
	    dx = state.s80;
	    dxx = state.s15;
	    g.setFont(normalfont);
	    fm = g.getFontMetrics();
	    dy = state.s10;
	    dyy = dy + state.s2;
	    
	    g.setFont(symbolfont);
	    g.getFontMetrics();
	    lambda="\u03bb";
	    Ohm="\u03a9";
	    infinity="\u221e";
	    g.setFont(normalfont);
	    g.getFontMetrics();
	    
	    g.setColor(bgcolor);
	    g.fillRect(0,0,getSize().width,getSize().height);
	    
	    g.setColor(Color.black);
	    g.drawLine(state.s5,state.s5,getSize().width - state.s5,state.s5);
	    
	    g.setColor(Color.blue);
	    g.drawString("Wavelength", x,y);
	    y +=dyy + state.s3;
	    
	    g.setColor(Color.black);
	    g.setFont(new Font("Serif",Font.PLAIN,state.font13));
	    g.drawString("\u03bb",x + state.s25,y);
	    g.setFont(new Font("SanSerif",Font.PLAIN,state.font12));
	    g.drawString("      =  "+MaestroA.rounder(state.lambda,8)+"  [ m ]",x+state.s25,y);
	    y += dyy - state.s3;
	    
	    g.setColor(Color.red);
	    g.drawLine(state.s5,y,getSize().width-state.s5,y);
	    y+=dyy;
	    y+=state.s3;	    
	    
	    g.setColor(Color.blue);
	    g.drawString("Dipole A - Length", x,y);
	    y +=dyy+state.s3;
	    	    
	    g.setColor(Color.black);    
	    MaestroG.subscripterIT("l","A","",g,state.font12,x+state.s20,y);
	    g.drawString("      = "+MaestroA.rounder(state.a,8)+"  "+lambda+"    = "+MaestroA.rounder(state.a * state.wavelength,8)+"  [ m ]",x+state.s25,y);
	    
            y +=dyy;
	    y +=dyy-state.s6;
	    
	    g.setColor(Color.blue);
	    g.drawString("Dipole B - Length", x,y);
	    y +=dyy+3;
	    	    
	    g.setColor(Color.black);    
	    MaestroG.subscripterIT("l","B","",g,state.font12,x+state.s20,y);
	    g.drawString("      = "+MaestroA.rounder(state.a2,8)+"  "+lambda+"    = "+MaestroA.rounder(state.a2 * state.wavelength,8)+"  [ m ]",x+state.s25,y);
	    
	    y +=dyy;
	    g.setColor(Color.red);
	    g.drawLine(state.s5,y,getSize().width-state.s5,y);
	    y+=dyy;
	    y+=state.s6;
	    
	    String unit_field;
	    double exponent_factor, Reale;
	    int exponent = 0;
	    exponent_factor = 0.0;
	    
	    g.setColor(Color.blue);
	    g.drawString("Directivity", x,y);
	    
	    g.setColor(Color.black);
	    g.drawString("D",x+state.s75,y);
	    g.setFont(new Font("SanSerif",Font.PLAIN,state.font12));
	    
	    unit_field =""; 
	    Reale = state.Directivity;
	    
	    //Magnitude
	    if(Reale<1000.0 && Reale>=1.0 || Reale == 0.0){
		exponent_factor = 1.0;
		exponent = 0;
	    }
	    if(Reale<1.0 && Reale>=1.0E-3){
		exponent_factor = 1.0E-3;
		exponent = -3;
	    }
	    if(Reale<1.0E6 && Reale>=1.0E3){
		exponent_factor = 1.0E3;
		exponent = 3;
	    }
	    if(Reale<1.0E-3 && Reale>=1.0E-6){
		exponent_factor = 1.0E-6;
		exponent = -6;
	    }
	    if(Reale<1.0E9 && Reale>=1.0E6){
		exponent_factor = 1.0E6;
		exponent = 6;
	    }
	    if(Reale<1.0E-6 && Reale>=1.0E-9){
		exponent_factor = 1.0E-9;
		exponent = -9;
	    }
	    if(Reale<1.0E12 && Reale>=1.0E9){
		exponent_factor = 1.0E9;
		exponent = 9;
	    }
	    if(Reale<1.0E-9 && Reale>=1.0E-12){
		exponent_factor = 1.0E-12;
		exponent = -12;
	    }
	    if(Reale<1.0E15 && Reale>=1.0E12){
		exponent_factor = 1.0E12;
		exponent = 12;
	    }
	    if(Reale<1.0E-12 && Reale>=1.0E-15){
		exponent_factor = 1.0E-15;
		exponent = -15;
	    }
	    if(Reale<1.0E18 && Reale>=1.0E15){
		exponent_factor = 1.0E15;
		exponent = 15;
	    }
	    if(Reale<1.0E-15 && Reale>=1.0E-18){
		exponent_factor = 1.0E-18;
		exponent = -18;
	    }
	    if(Reale<1.0E21 && Reale>=1.0E18){
		exponent_factor = 1.0E18;
		exponent = 18;
	    }
	    if(Reale<1.0E-18 && Reale>=1.0E-21){
		exponent_factor = 1.0E-21;
		exponent = -21;
	    }
	    if(Reale<1.0E24 && Reale>=1.0E21){
		exponent_factor = 1.0E21;
		exponent = 21;
	    }
	    if(Reale<1.0E-21 && Reale>=1.0E-24){
		exponent_factor = 1.0E-24;
		exponent = -24;
	    }
	    if(Reale<1.0E27 && Reale>=1.0E24){
		exponent_factor = 1.0E24;
		exponent = 24;
	    }
	    if(Reale<1.0E-24 && Reale>=1.0E-27){
		exponent_factor = 1.0E-27;
		exponent = -27;
	    }
	    if(Reale<1.0E30 && Reale>=1.0E27){
		exponent_factor = 1.0E27;
		exponent = 27;
	    }
	    if(Reale<1.0E-27 && Reale>=1.0E-30){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }
	    if(Reale>1.0E30){
		exponent_factor = 1.0E30;
		exponent = 30;
	    }
	    if(Reale<1.0E-30 && Reale > 0.0){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }
	    if(exponent == 0){
	    MaestroG.superscripter("     =  "+MaestroA.rounder(Reale/exponent_factor,5)+"","",
				   " "+unit_field,g,state.font12,x+state.s80,y);
	    }
	    else{
	    MaestroG.superscripter("     =  "+MaestroA.rounder(Reale/exponent_factor,5)+" x 10",""+exponent,
				   " "+unit_field,g,state.font12,x+state.s80,y);
	    }    
	    
	    y +=dyy;
	    g.setColor(Color.red);
	    g.drawLine(state.s5,y,getSize().width-state.s5,y);
	    y+=dyy;
	    y+=state.s6;
	      
	    g.setColor(Color.blue);
	    g.drawString("Time-Average Total Radiated Power", x,y);
	    y +=dyy+state.s3;
	    
	    g.setColor(Color.black);
	    
	    MaestroG.subscripter("< P","tot"," >",g,state.font12,x,y);
	    
	    unit_field ="[ W ]"; 
	    Reale = state.TotalPower;
	    
	    //Magnitude
	    if(Reale<1000.0 && Reale>=1.0 || Reale == 0.0){
		exponent_factor = 1.0;
		exponent = 0;
	    }
	    if(Reale<1.0 && Reale>=1.0E-3){
		exponent_factor = 1.0E-3;
		exponent = -3;
	    }
	    if(Reale<1.0E6 && Reale>=1.0E3){
		exponent_factor = 1.0E3;
		exponent = 3;
	    }
	    if(Reale<1.0E-3 && Reale>=1.0E-6){
		exponent_factor = 1.0E-6;
		exponent = -6;
	    }
	    if(Reale<1.0E9 && Reale>=1.0E6){
		exponent_factor = 1.0E6;
		exponent = 6;
	    }
	    if(Reale<1.0E-6 && Reale>=1.0E-9){
		exponent_factor = 1.0E-9;
		exponent = -9;
	    }
	    if(Reale<1.0E12 && Reale>=1.0E9){
		exponent_factor = 1.0E9;
		exponent = 9;
	    }
	    if(Reale<1.0E-9 && Reale>=1.0E-12){
		exponent_factor = 1.0E-12;
		exponent = -12;
	    }
	    if(Reale<1.0E15 && Reale>=1.0E12){
		exponent_factor = 1.0E12;
		exponent = 12;
	    }
	    if(Reale<1.0E-12 && Reale>=1.0E-15){
		exponent_factor = 1.0E-15;
		exponent = -15;
	    }
	    if(Reale<1.0E18 && Reale>=1.0E15){
		exponent_factor = 1.0E15;
		exponent = 15;
	    }
	    if(Reale<1.0E-15 && Reale>=1.0E-18){
		exponent_factor = 1.0E-18;
		exponent = -18;
	    }
	    if(Reale<1.0E21 && Reale>=1.0E18){
		exponent_factor = 1.0E18;
		exponent = 18;
	    }
	    if(Reale<1.0E-18 && Reale>=1.0E-21){
		exponent_factor = 1.0E-21;
		exponent = -21;
	    }
	    if(Reale<1.0E24 && Reale>=1.0E21){
		exponent_factor = 1.0E21;
		exponent = 21;
	    }
	    if(Reale<1.0E-21 && Reale>=1.0E-24){
		exponent_factor = 1.0E-24;
		exponent = -24;
	    }
	    if(Reale<1.0E27 && Reale>=1.0E24){
		exponent_factor = 1.0E24;
		exponent = 24;
	    }
	    if(Reale<1.0E-24 && Reale>=1.0E-27){
		exponent_factor = 1.0E-27;
		exponent = -27;
	    }
	    if(Reale<1.0E30 && Reale>=1.0E27){
		exponent_factor = 1.0E27;
		exponent = 27;
	    }
	    if(Reale<1.0E-27 && Reale>=1.0E-30){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }
	    if(Reale>1.0E30){
		exponent_factor = 1.0E30;
		exponent = 30;
	    }
	    if(Reale<1.0E-30 && Reale > 0.0){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }
	    if(exponent == 0){
	    MaestroG.superscripter("     =  "+MaestroA.rounder(Reale/exponent_factor,5)+"","",
				   " "+unit_field,g,state.font12,x+state.s30,y);
	    }
	    else{
	    MaestroG.superscripter("     =  "+MaestroA.rounder(Reale/exponent_factor,5)+" x 10",""+exponent,
				   " "+unit_field,g,state.font12,x+state.s30,y);
	    }   
	    
	    y+=dyy-state.s2;
	    
	    g.setColor(Color.red);
	    g.drawLine(5,y,getSize().width-state.s5,y);
	    y+=dyy;
	    y+=state.s6;
	    
	    g.setColor(Color.blue);
	    g.drawString("Assumptions", x,y);
	    y +=dyy+state.s3;
	    
	    g.setColor(Color.black);
	    g.drawString("- Gap between radiating elements is neglected.", x,y);
	}
}

    class NewOutputCanvasB extends Canvas{
	private Font normalfont = new Font("SanSerif",Font.PLAIN,12);
	private Font subfont    = new Font("SanSerif",Font.PLAIN,10);
	private Font symbolfont=new Font("Serif",Font.PLAIN,12);
	
        NewGuide_State state;
	private Image im;
	private Graphics buf;
	
        public NewOutputCanvasB(NewGuide_State state){
	    super();
	    this.state = state;
	}
	
	public void paint(Graphics g){
	    if(im == null){
		im = createImage(getSize().width,getSize().height);
		buf = im.getGraphics();
		drawCanvas(buf);
	    }
	    else{
		drawCanvas(buf);
	    }
	    g.drawImage(im,0,0,null);
	}

	//Addition to reduce flicker new routine
	public void update(Graphics g){		// added to avoid clearing
	    paint(g);
	}
	
	public void clear(){
	    this.getGraphics().clearRect(0,0,getSize().width,getSize().height);
	    repaint();
	}

	public void drawCanvas(Graphics g){
	    normalfont = new Font("SanSerif",Font.PLAIN,state.font12);
            subfont = new Font("SanSerif",Font.PLAIN,state.font10);
            symbolfont=new Font("Serif",Font.PLAIN,state.font12);
            
            int x, y, dx, dxx, dy, dyy;
	    double v_normalized;
	    Color bgcolor = new Color(236,236,221);
	    String stmp;
	    String lambda, Ohm;
	    FontMetrics fm;
	    
	    x = state.s10;
	    y = state.s25;
	    dx = state.s80;
	    dxx = state.s15;
	    g.setFont(normalfont);
	    fm = g.getFontMetrics();
	    dy = state.s12;
	    dyy = dy+state.s1;
	    
	    lambda="\u03bb";
	    Ohm="\u03a9";
	    g.setFont(normalfont);
	    g.getFontMetrics();
	    	    
	    g.setColor(bgcolor);
	    g.fillRect(0,0,getSize().width,getSize().height);
	    
	    g.setColor(Color.black);
	    g.drawLine(state.s5,state.s5,getSize().width-state.s5,state.s5);
	    
	    g.setColor(Color.blue);
	    g.drawString("Wavelength", x,y);
	    y +=dyy+state.s3;
	    
	    g.setColor(Color.black);
	    g.setFont(new Font("Serif",Font.PLAIN,state.font12));
	    g.drawString("\u03bb",x+state.s25,y);
	    g.setFont(new Font("SanSerif",Font.PLAIN,state.font12));
	    g.drawString("      =  "+MaestroA.rounder(state.lambda,8)+"  [ m ]",x+state.s25,y);
	    y +=dyy - state.s3;
	    
	    g.setColor(Color.red);
	    g.drawLine(state.s5,y,getSize().width-state.s5,y);
	    y+=dyy;
	    y+= state.s3;
	    
	    g.setColor(Color.blue);
	    g.drawString("Dipole A - Length", x,y);
	    y +=dyy + state.s3;
	    	    
	    g.setColor(Color.black);    
	    MaestroG.subscripter("L","A","",g,state.font12,x+state.s20,y);
	    
	    g.drawString("      = "+MaestroA.rounder(state.a,8)+"  "+lambda+"    = "+MaestroA.rounder(state.a * state.wavelength,8)+"  [ m ]",x+state.s25,y);
	    y +=dyy;
	    y +=dyy - state.s6;
	    
	    g.setColor(Color.blue);
	    g.drawString("Dipole B - Length", x,y);
	    y +=dyy + state.s3;
	    	    
	    g.setColor(Color.black);    
	    MaestroG.subscripter("L","B","",g,state.font12,x+state.s20,y);
	    g.drawString("      = "+MaestroA.rounder(state.a2,8)+"  "+lambda+"    = "+MaestroA.rounder(state.a2 * state.wavelength,8)+"  [ m ]",x+state.s25,y);
	    
	    y +=dyy;
	    g.setColor(Color.red);
	    g.drawLine(state.s5,y,getSize().width-state.s5,y);
	    y+=dyy;
	    y+=state.s2;
	    g.setColor(Color.blue);
	    g.drawString("Discretization intervals for 3-D fields", x,y);
	    y +=dyy+state.s3;
	    g.setColor(Color.black);
	    
	    MaestroG.subscripter("N","A"," = "+state.Nsections,g,state.font12,x+state.s25,y);
	    MaestroG.subscripter("N","B"," = "+state.Nsections2,g,state.font12,x+state.s125,y);
	    y+=dyy+5;
	    
	    g.setColor(Color.blue);
	    g.drawString("Length of discretization intervals", x,y);
	    y +=dyy+state.s3;
	    g.setColor(Color.black);
	    
	    g.setFont(new Font("Serif",Font.PLAIN,state.font12));
	    g.drawString("\u0394",x+state.s25,y);
	    g.setFont(new Font("SanSerif",Font.PLAIN,state.font12));
	    
	    MaestroG.subscripter("    z","A"," = "+(MaestroA.rounder(state.DeltaZ,8))+"  [ m ]",g,state.font12,x+state.s25,y);
	    y +=dyy+6;
	    g.setFont(new Font("Serif",Font.PLAIN,state.font12));
	    g.drawString("\u0394",x+state.s25,y);
	    g.setFont(new Font("SanSerif",Font.PLAIN,state.font12));
	    
	    MaestroG.subscripter("    z","B"," = "+(MaestroA.rounder(state.DeltaZ2,8))+"  [ m ]",g,state.font12,x+state.s25,y);
	    
	    y+=dyy+state.s3;	    
	    g.setColor(Color.blue);
	    g.drawString("Discretization intervals for current plot", x,y);
	    y +=dyy+state.s3;
	    
	    g.setColor(Color.black);
	    MaestroG.subscripter("N","c"," = "+(state.NsectionsLarge-1),g,state.font12,x+state.s25,y);
    }
}

class NewOutputCanvasField extends Canvas {
	private static final Color bgcolor = new Color(236,236,221);
	private Font labfont = new Font("SanSerif",Font.PLAIN,12);
	private Font normalfont = new Font("SanSerif",Font.PLAIN,12);
	private Font subfont = new Font("SanSerif",Font.PLAIN,10);
	private Font symbolfont = new Font("Serif",Font.PLAIN,12);
	public String string_field, unit_field; 
	int x, y;
	public Complex field;
	public double fieldfar;
	NewGuide_State state;
	NewGuideCanvas rcanvas;
	private Image im;
	private Graphics buf;
	private boolean IsFocusOn, IsTopoOn;
    
    private BufferedImage red_angle, blue_angle;
	
	public NewOutputCanvasField(NewGuide_State state, NewGuideCanvas rcanvas){
	    super();
	    this.state = state;
	    getImages();
	    this.rcanvas = rcanvas;
	    IsFocusOn = false;
	    IsTopoOn = false;
	}


    private void getImages() {
        // read in the angle images, because CHEERPJ does not render this
	//  symbol in any font!  (java to javascript converter)
        try {
            //red_angle = ImageIO.read(getClass().getResource("red_angle.png"));
	    BufferedImage img =
		ImageIO.read(getClass().getResource("red_angle.png"));
	    int targetWidth = (int) (state.sfactor * img.getWidth());
	    int targetHeight = (int) (state.sfactor * img.getHeight());
	    red_angle =
		new BufferedImage(targetWidth, targetHeight, BufferedImage.TYPE_INT_RGB);
	    Graphics2D graphics2D = red_angle.createGraphics();
	    graphics2D.setRenderingHint(RenderingHints.KEY_INTERPOLATION,
					RenderingHints.VALUE_INTERPOLATION_BILINEAR);
	    graphics2D.drawImage(img, 0, 0, targetWidth, targetHeight, 0, 0,
				 img.getWidth(), img.getHeight(), null);
	    graphics2D.dispose();

	    img = ImageIO.read(getClass().getResource("blue_angle.png"));
	    targetWidth = (int) (state.sfactor * img.getWidth());
	    targetHeight = (int) (state.sfactor * img.getHeight());
	    blue_angle =
		new BufferedImage(targetWidth, targetHeight, BufferedImage.TYPE_INT_RGB);
	    graphics2D = blue_angle.createGraphics();
	    graphics2D.setRenderingHint(RenderingHints.KEY_INTERPOLATION,
					RenderingHints.VALUE_INTERPOLATION_BILINEAR);
	    graphics2D.drawImage(img, 0, 0, targetWidth, targetHeight, 0, 0,
				 img.getWidth(), img.getHeight(), null);
	    graphics2D.dispose();

        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    
	
	public void paint(Graphics g){
	    if(im == null){
		im = createImage(getSize().width,getSize().height);
		buf = im.getGraphics();
		drawCanvas(buf);
	    }
	    else{
		drawCanvas(buf);
	    }
	    g.drawImage(im,0,0,null);
	}

	//Addition to reduce flicker new routine
	public void update(Graphics g){		// added to avoid clearing
	    paint(g);
	}
	
	public void clear(){
	    this.getGraphics().clearRect(0,0,getSize().width,getSize().height);
	    repaint();
	}

	public void drawCanvas(Graphics g){
            labfont = new Font("SanSerif",Font.PLAIN,state.font12);
            normalfont = new Font("SanSerif",Font.PLAIN,state.font12);
            subfont = new Font("SanSerif",Font.PLAIN,state.font10);
            symbolfont = new Font("Serif",Font.PLAIN,state.font12);
	
            Graphics2D g2d = (Graphics2D)g;
            g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING,RenderingHints.VALUE_ANTIALIAS_ON);
	    int dx, dxx, dy, dyy;
	    double tempcap, Cond1, Res1, tempind, f_normalized;
	    Color bgcolor = new Color(236,236,221);
	    String stmp;
	    FontMetrics fm;
	    
	    double light_velocity = 1.0/Math.sqrt(state.epsilon0*state.mu0*state.epsilon_r);
	    double light_velocity0 = 1.0/Math.sqrt(state.epsilon0*state.mu0);
	    String lambda, Ohm, theta, phi, deg;
	    x = state.s1;
	    y = state.s5;
	    dx = state.s75;
	    dxx = state.s15;
	    g.setFont(normalfont);
	    fm = g.getFontMetrics();
	    dy = state.s10;
	    dyy = dy+state.s2;
	    
	    g.setFont(symbolfont);
	    g.getFontMetrics();
	    lambda="\u03bb";
	    Ohm="\u03a9";
	    lambda="\u03bb";
	    theta="\u03b8";
	    phi="\u03c6";
	    deg="\u00ba";
	    g.setFont(normalfont);
	    g.getFontMetrics();
	    
	    g.setColor(bgcolor);
	    g.fillRect(0,0,getSize().width,getSize().height);
	    
	    g.setColor(Color.black);
	    g.drawLine(state.s5,y,getSize().width-state.s5,y);
	    y+=dyy;
	    y+=state.s7;
	    g.drawString("Numerical Calculation", x,y);
	    
	    //draw field choices
		//if(IsTopoOn)
		{
                    g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING,RenderingHints.VALUE_ANTIALIAS_ON);
    
                    if(!IsFocusOn){
			g.setColor(Color.white);
			g.fillOval(state.s200,y-state.s10,state.s10,state.s10);
			g.setColor(Color.red);
			g.drawString("E",state.s200+state.s15,y);
			g.fillOval(state.s200,y-state.s10,state.s10,state.s10);
			
			g.setColor(Color.white);
			g.fillOval(state.s200+state.s40,y-state.s10,state.s10,state.s10);
			g.setColor(Color.blue);
			g.drawString("H",state.s200+state.s55,y);	
			g.drawOval(state.s200+state.s40,y-state.s10,state.s10,state.s10);
			state.IsEfield = true;
		    }
		    else{
			g.setColor(Color.white);
			g.fillOval(state.s200,y-state.s10,state.s10,state.s10);
			g.setColor(Color.red);
			g.drawString("E",state.s200+state.s15,y);
			g.drawOval(state.s200,y-state.s10,state.s10,state.s10);
			
			g.setColor(Color.white);
			g.fillOval(state.s200+state.s40,y-state.s10,state.s10,state.s10);
			g.setColor(Color.blue);
			g.drawString("H",state.s200+state.s55,y);	
			g.fillOval(state.s200+state.s40,y-state.s10,state.s10,state.s10);
			state.IsEfield = false;
		    }
                    //g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING,RenderingHints.VALUE_ANTIALIAS_OFF);
		}
	    //------------------------
	    y +=dyy+state.s6;
	   
	    if(!IsFocusOn){ 
		g.setColor(Color.red);
		MaestroG.subscripterSymbol("E","\u03b8","",g,state.font12,x+state.s5,y);
		unit_field=" V/m";
		field = state.ethetaC;
	    
		stringa(g);
		y+=dyy;
		stringe(g);
	    
		y +=dyy+state.s4;
	    
		MaestroG.subscripterS("E","R","",g,state.font12,x+state.s5,y);
		unit_field=" V/m";
		field = state.eradC;
		stringa(g);
		y+=dyy;
		stringe(g);
	    
		y +=dyy+state.s4;
		
		MaestroG.subscripterSymbol("E","\u03c6","",g,state.font12,x+state.s5,y);
		unit_field=" A/m";
		field = state.ephigenC;
		stringa(g);
		y+=dyy;
		stringe(g);
	    }
	    else{
		g.setColor(Color.blue);
		MaestroG.subscripterSymbol("H","\u03c6","",g,state.font12,x+state.s5,y);
		unit_field=" A/m";
		field = state.hphigenC;
		stringa(g);
		y+=dyy;
		stringe(g);
		
		y +=dyy+state.s4;
		
		MaestroG.subscripterSymbol("H","\u03b8","",g,state.font12,x+state.s5,y);
		unit_field=" A/m";
		field = state.hthetaC;
	    
		stringa(g);
		y+=dyy;
		stringe(g);
	    
		y +=dyy+state.s4;
	
		MaestroG.subscripterS("H","R","",g,state.font12,x+state.s5,y);
		unit_field=" A/m";
		field = state.hradC;
		stringa(g);
		y+=dyy;
		stringe(g);
	    }
	    
	    y +=dyy-state.s4;
	    g.setColor(Color.red);
	    g.drawLine(state.s5,y,getSize().width-state.s5,y);
	    y+=dyy;
	    y+=state.s6;
	    
	    g.setFont(normalfont);
	    g.getFontMetrics();
	    g.setColor(Color.black);
	    g.drawString("Far-Field Approximation", x,y);
	    
	    y +=dyy+6;
	    
	    g.setColor(Color.red);
	    MaestroG.subscripterSymbol("E","\u03b8","",g,state.font12,x+state.s5,y);
	    unit_field=" V/m";
	    field = state.EfarC;
	    stringa(g);
	    y+=dyy;
	    stringe(g);
	    
	    y +=dyy+state.s6;
	    
	    g.setColor(Color.blue);
	    MaestroG.subscripterSymbol("H","\u03c6","",g,state.font12,x+state.s5,y);
	    unit_field=" A/m";
	    field = state.HfarC;
	    stringa(g);
	    y+=dyy;
	    stringe(g);
	    y +=state.s7;
	    g.setColor(Color.red);
	    g.drawLine(state.s5,y,getSize().width-state.s5,y);
	    
	    y +=dyy+state.s5;
	    
	    g.setFont(normalfont);
	    g.getFontMetrics();
	    g.setColor(Color.black);
	    g.drawString("Time-average Power Density", x,y);
	    
	    y +=dyy+state.s3;
	    
	    g.setColor(new Color(150,0,0));
	    MaestroG.subscripterS("< P","R"," >",g,state.font12,x+state.s3,y);
	    unit_field=" W/m\u00b2";
	    fieldfar = state.Pfar;
	    stringp(g);
	}

    /*
	//----------------  mouse routines
	public void mouseClicked(MouseEvent evt){
	    if(IsFocusOn){
		IsFocusOn = false;
		state.IsEfield = true;
		rcanvas.setField(state.IsEfield);
		rcanvas.repaint();
		repaint();
	    }
	
	    else{
		IsFocusOn = true;
		state.IsEfield = false;
		rcanvas.setField(state.IsEfield);
		rcanvas.repaint();
		repaint();
	    }
	}
    
	public void mouseEntered(MouseEvent evt){
	    IsTopoOn = true;
	    repaint();
	}
	public void mouseExited(MouseEvent evt){
	    IsTopoOn = false;
	    repaint();
	}
	
	public void mousePressed(MouseEvent evt){}
	public void mouseReleased(MouseEvent evt){} 
    */
	 
	//----------------------------------------
	 
	
	
	private void stringa(Graphics g){
	    String sign, sign2;
	    double exponent_factorR, exponent_factorI, Reale, Immaginario;
	    int exponentR, exponentI;
	    
	    //Determine sign
	    if(Complex.Imaginary(field) < 0.0){
		sign ="  - j ";
	    }
	    else{
		sign =" + j ";
	    }
	    
	    if(Complex.Real(field) < 0.0){
		sign2 =" - ";
	    }
	    else{
		sign2 ="  ";
	    }
	    
	    exponent_factorR = 0.0;
	    exponentR = 0;
	    
	    Reale = Math.abs(Complex.Real(field));
	    Immaginario = Math.abs(Complex.Imaginary(field));
	    
	    //Real Part
	    if(Reale < 1000.0 && Reale >= 1.0 || Reale == 0.0){
		exponent_factorR = 1.0;
		exponentR = 0;
	    }
	    if(Reale<1.0 && Reale>=1.0E-3){
		exponent_factorR = 1.0E-3;
		exponentR = -3;
	    }
	    if(Reale<1.0E6 && Reale>=1.0E3){
		exponent_factorR = 1.0E3;
		exponentR = 3;
	    }
	    if(Reale<1.0E-3 && Reale>=1.0E-6){
		exponent_factorR = 1.0E-6;
		exponentR = -6;
	    }
	    if(Reale<1.0E9 && Reale>=1.0E6){
		exponent_factorR = 1.0E6;
		exponentR = 6;
	    }
	    if(Reale<1.0E-6 && Reale>=1.0E-9){
		exponent_factorR = 1.0E-9;
		exponentR = -9;
	    }
	    if(Reale<1.0E12 && Reale>=1.0E9){
		exponent_factorR = 1.0E9;
		exponentR = 9;
	    }
	    if(Reale<1.0E-9 && Reale>=1.0E-12){
		exponent_factorR = 1.0E-12;
		exponentR = -12;
	    }
	    if(Reale<1.0E15 && Reale>=1.0E12){
		exponent_factorR = 1.0E12;
		exponentR = 12;
	    }
	    if(Reale<1.0E-12 && Reale>=1.0E-15){
		exponent_factorR = 1.0E-15;
		exponentR = -15;
	    }
	    if(Reale<1.0E18 && Reale>=1.0E15){
		exponent_factorR = 1.0E15;
		exponentR = 15;
	    }
	    if(Reale<1.0E-15 && Reale>=1.0E-18){
		exponent_factorR = 1.0E-18;
		exponentR = -18;
	    }
	    if(Reale<1.0E21 && Reale>=1.0E18){
		exponent_factorR = 1.0E18;
		exponentR = 18;
	    }
	    if(Reale<1.0E-18 && Reale>=1.0E-21){
		exponent_factorR = 1.0E-21;
		exponentR = -21;
	    }
	    if(Reale<1.0E24 && Reale>=1.0E21){
		exponent_factorR = 1.0E21;
		exponentR = 21;
	    }
	    if(Reale<1.0E-21 && Reale>=1.0E-24){
		exponent_factorR = 1.0E-24;
		exponentR = -24;
	    }
	    if(Reale<1.0E27 && Reale>=1.0E24){
		exponent_factorR = 1.0E24;
		exponentR = 24;
	    }
	    if(Reale<1.0E-24 && Reale>=1.0E-27){
		exponent_factorR = 1.0E-27;
		exponentR = -27;
	    }
	    if(Reale<1.0E30 && Reale>=1.0E27){
		exponent_factorR = 1.0E27;
		exponentR = 27;
	    }
	    if(Reale<1.0E-27 && Reale>=1.0E-30){
		exponent_factorR = 1.0E-30;
		exponentR = -30;
	    }
	    if(Reale>1.0E30){
		exponent_factorR = 1.0E30;
		exponentR = 30;
	    }
	    if(Reale<1.0E-30 && Reale > 0.0){
		exponent_factorR = 1.0E-30;
		exponentR = -30;
	    }
	    
	    exponent_factorI = 0.0;
	    exponentI = 0;
	    // Imaginary Part
	    if(Immaginario<1000.0 && Immaginario>=1.0 || Immaginario == 0.0){
		exponent_factorI = 1.0;
		exponentI = 0;
	    }
	    if(Immaginario<1.0 && Immaginario>=1.0E-3){
		exponent_factorI = 1.0E-3;
		exponentI = -3;
	    }
	    if(Immaginario<1.0E6 && Immaginario>=1.0E3){
		exponent_factorI = 1.0E3;
		exponentI = 3;
	    }
	    if(Immaginario<1.0E-3 && Immaginario>=1.0E-6){
		exponent_factorI = 1.0E-6;
		exponentI = -6;
	    }
	    if(Immaginario<1.0E9 && Immaginario>=1.0E6){
		exponent_factorI = 1.0E6;
		exponentI = 6;
	    }
	    if(Immaginario<1.0E-6 && Immaginario>=1.0E-9){
		exponent_factorI = 1.0E-9;
		exponentI = -9;
	    }
	    if(Immaginario<1.0E12 && Immaginario>=1.0E9){
		exponent_factorI = 1.0E9;
		exponentI = 9;
	    }
	    if(Immaginario<1.0E-9 && Immaginario>=1.0E-12){
		exponent_factorI = 1.0E-12;
		exponentI = -12;
	    }
	    if(Immaginario<1.0E15 && Immaginario>=1.0E12){
		exponent_factorI = 1.0E12;
		exponentI = 12;
	    }
	    if(Immaginario<1.0E-12 && Immaginario>=1.0E-15){
		exponent_factorI = 1.0E-15;
		exponentI = -15;
	    }
	    if(Immaginario<1.0E18 && Immaginario>=1.0E15){
		exponent_factorI = 1.0E15;
		exponentI = 15;
	    }
	    if(Immaginario<1.0E-15 && Immaginario>=1.0E-18){
		exponent_factorI = 1.0E-18;
		exponentI = -18;
	    }
	    if(Immaginario<1.0E21 && Immaginario>=1.0E18){
		exponent_factorI = 1.0E18;
		exponentI = 18;
	    }
	    if(Immaginario<1.0E-18 && Immaginario>=1.0E-21){
		exponent_factorI = 1.0E-21;
		exponentI = -21;
	    }
	    if(Immaginario<1.0E24 && Immaginario>=1.0E21){
		exponent_factorI = 1.0E21;
		exponentI = 21;
	    }
	    if(Immaginario<1.0E-21 && Immaginario>=1.0E-24){
		exponent_factorI = 1.0E-24;
		exponentI = -24;
	    }
	    if(Immaginario<1.0E27 && Immaginario>=1.0E24){
		exponent_factorI = 1.0E24;
		exponentI = 24;
	    }
	    if(Immaginario<1.0E-24 && Immaginario>=1.0E-27){
		exponent_factorI = 1.0E-27;
		exponentI = -27;
	    }
	    if(Immaginario<1.0E30 && Immaginario>=1.0E27){
		exponent_factorI = 1.0E27;
		exponentI = 27;
	    }
	    if(Immaginario<1.0E-27 && Immaginario>=1.0E-30){
		exponent_factorI = 1.0E-30;
		exponentI = -30;
	    }
	    if(Reale>1.0E30){
		exponent_factorI = 1.0E30;
		exponentI = 30;
	    }
	    if(Immaginario<1.0E-30 && Immaginario > 0.0){
		exponent_factorI = 1.0E-30;
		exponentI = -30;
	    }
	    
	    if(exponentR == 0 && exponentI == 0){
		MaestroG.doublesuperscripter("= "+sign2+MaestroA.rounder(Reale/exponent_factorR,3)+"","",
				   ""+sign+MaestroA.rounder(Immaginario/exponent_factorI,3)+"","",
				   " "+unit_field,g,state.font10,x+state.s25,y);
	    }
	    else if(exponentR == 0 && exponentI != 0){
		MaestroG.doublesuperscripter("= "+sign2+MaestroA.rounder(Reale/exponent_factorR,3)+"","",
				   ""+sign+MaestroA.rounder(Immaginario/exponent_factorI,3)+" x 10",""+exponentI,
				   " "+unit_field,g,state.font10,x+state.s25,y);
	    }
	    else if(exponentR != 0 && exponentI == 0){
		MaestroG.doublesuperscripter("= "+sign2+MaestroA.rounder(Reale/exponent_factorR,3)+" x 10",""+exponentR,
				   ""+sign+MaestroA.rounder(Immaginario/exponent_factorI,3)+"","",
				   " "+unit_field,g,state.font10,x+state.s25,y);
	    }
	    else{
		MaestroG.doublesuperscripter("= "+sign2+MaestroA.rounder(Reale/exponent_factorR,3)+" x 10",""+exponentR,
				   ""+sign+MaestroA.rounder(Immaginario/exponent_factorI,3)+" x 10",""+exponentI,
				   " "+unit_field,g,state.font10,x+state.s25,y);
	    }
	} 
	
	private void stringe(Graphics g){
	    String sign, sign2;
	    double exponent_factor, Reale;
	    int exponent;
	       
	    exponent_factor = 0.0;
	    exponent = 0;
	    
	    Reale = Complex.Magnitude(field);
	    
	    //Magnitude
	    if(Reale<1000.0 && Reale>=1.0 || Reale == 0.0){
		exponent_factor = 1.0;
		exponent = 0;
	    }
	    if(Reale<1.0 && Reale>=1.0E-3){
		exponent_factor = 1.0E-3;
		exponent = -3;
	    }
	    if(Reale<1.0E6 && Reale>=1.0E3){
		exponent_factor = 1.0E3;
		exponent = 3;
	    }
	    if(Reale<1.0E-3 && Reale>=1.0E-6){
		exponent_factor = 1.0E-6;
		exponent = -6;
	    }
	    if(Reale<1.0E9 && Reale>=1.0E6){
		exponent_factor = 1.0E6;
		exponent = 6;
	    }
	    if(Reale<1.0E-6 && Reale>=1.0E-9){
		exponent_factor = 1.0E-9;
		exponent = -9;
	    }
	    if(Reale<1.0E12 && Reale>=1.0E9){
		exponent_factor = 1.0E9;
		exponent = 9;
	    }
	    if(Reale<1.0E-9 && Reale>=1.0E-12){
		exponent_factor = 1.0E-12;
		exponent = -12;
	    }
	    if(Reale<1.0E15 && Reale>=1.0E12){
		exponent_factor = 1.0E12;
		exponent = 12;
	    }
	    if(Reale<1.0E-12 && Reale>=1.0E-15){
		exponent_factor = 1.0E-15;
		exponent = -15;
	    }
	    if(Reale<1.0E18 && Reale>=1.0E15){
		exponent_factor = 1.0E15;
		exponent = 15;
	    }
	    if(Reale<1.0E-15 && Reale>=1.0E-18){
		exponent_factor = 1.0E-18;
		exponent = -18;
	    }
	    if(Reale<1.0E21 && Reale>=1.0E18){
		exponent_factor = 1.0E18;
		exponent = 18;
	    }
	    if(Reale<1.0E-18 && Reale>=1.0E-21){
		exponent_factor = 1.0E-21;
		exponent = -21;
	    }
	    if(Reale<1.0E24 && Reale>=1.0E21){
		exponent_factor = 1.0E21;
		exponent = 21;
	    }
	    if(Reale<1.0E-21 && Reale>=1.0E-24){
		exponent_factor = 1.0E-24;
		exponent = -24;
	    }
	    if(Reale<1.0E27 && Reale>=1.0E24){
		exponent_factor = 1.0E24;
		exponent = 24;
	    }
	    if(Reale<1.0E-24 && Reale>=1.0E-27){
		exponent_factor = 1.0E-27;
		exponent = -27;
	    }
	    if(Reale<1.0E30 && Reale>=1.0E27){
		exponent_factor = 1.0E27;
		exponent = 27;
	    }
	    if(Reale<1.0E-27 && Reale>=1.0E-30){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }
	    if(Reale>1.0E30){
		exponent_factor = 1.0E30;
		exponent = 30;
	    }
	    if(Reale<1.0E-30 && Reale > 0.0){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }

	    BufferedImage angle;
	    if (g.getColor() == Color.blue) {
		//System.out.println("Color is blue");
		angle = blue_angle;
	    } else {
		//System.out.println("Color is red");
		angle = red_angle;
	    }
	    
		if(exponent == 0){
		    //MaestroG.superscripter("= "+MaestroA.rounder(Reale/exponent_factor,3)+"","",
		    //		   " \u2220 "+MaestroA.rounder(Complex.Arg2(field),3)+" rad",g,state.font10,x+state.s25,y);
		    MaestroG.TxtSupImgTxt("= "+MaestroA.rounder(Reale/exponent_factor,3)+"","",angle,
					  ""+MaestroA.rounder(Complex.Arg2(field),3)+" rad",g,state.font10,x+state.s25,y,this);
		}
		else{
		    //MaestroG.superscripter("= "+MaestroA.rounder(Reale/exponent_factor,3)+" x 10",""+exponent,
		    //		   " \u2220 "+MaestroA.rounder(Complex.Arg2(field),3)+" rad",g,state.font10,x+state.s25,y);
		    MaestroG.TxtSupImgTxt("= "+MaestroA.rounder(Reale/exponent_factor,3)+" x 10",""+exponent,angle,
					  ""+MaestroA.rounder(Complex.Arg2(field),3)+" rad",g,state.font10,x+state.s25,y,this);
		}
	} 
	
	private void stringm(Graphics g){
	    String sign;
	    double exponent_factor, Reale;
	    int exponent;
	    
	    //Determine sign
	    if(fieldfar < 0.0){
		sign ="  - j ";
	    }
	    else{
		sign ="   j ";
	    }
	       
	    exponent_factor = 0.0;
	    exponent = 0;
	    
	    Reale = Math.abs(fieldfar);
	    
	    //Magnitude
	    if(Reale<1000.0 && Reale>=1.0 || Reale == 0.0){
		exponent_factor = 1.0;
		exponent = 0;
	    }
	    if(Reale<1.0 && Reale>=1.0E-3){
		exponent_factor = 1.0E-3;
		exponent = -3;
	    }
	    if(Reale<1.0E6 && Reale>=1.0E3){
		exponent_factor = 1.0E3;
		exponent = 3;
	    }
	    if(Reale<1.0E-3 && Reale>=1.0E-6){
		exponent_factor = 1.0E-6;
		exponent = -6;
	    }
	    if(Reale<1.0E9 && Reale>=1.0E6){
		exponent_factor = 1.0E6;
		exponent = 6;
	    }
	    if(Reale<1.0E-6 && Reale>=1.0E-9){
		exponent_factor = 1.0E-9;
		exponent = -9;
	    }
	    if(Reale<1.0E12 && Reale>=1.0E9){
		exponent_factor = 1.0E9;
		exponent = 9;
	    }
	    if(Reale<1.0E-9 && Reale>=1.0E-12){
		exponent_factor = 1.0E-12;
		exponent = -12;
	    }
	    if(Reale<1.0E15 && Reale>=1.0E12){
		exponent_factor = 1.0E12;
		exponent = 12;
	    }
	    if(Reale<1.0E-12 && Reale>=1.0E-15){
		exponent_factor = 1.0E-15;
		exponent = -15;
	    }
	    if(Reale<1.0E18 && Reale>=1.0E15){
		exponent_factor = 1.0E15;
		exponent = 15;
	    }
	    if(Reale<1.0E-15 && Reale>=1.0E-18){
		exponent_factor = 1.0E-18;
		exponent = -18;
	    }
	    if(Reale<1.0E21 && Reale>=1.0E18){
		exponent_factor = 1.0E18;
		exponent = 18;
	    }
	    if(Reale<1.0E-18 && Reale>=1.0E-21){
		exponent_factor = 1.0E-21;
		exponent = -21;
	    }
	    if(Reale<1.0E24 && Reale>=1.0E21){
		exponent_factor = 1.0E21;
		exponent = 21;
	    }
	    if(Reale<1.0E-21 && Reale>=1.0E-24){
		exponent_factor = 1.0E-24;
		exponent = -24;
	    }
	    if(Reale<1.0E27 && Reale>=1.0E24){
		exponent_factor = 1.0E24;
		exponent = 24;
	    }
	    if(Reale<1.0E-24 && Reale>=1.0E-27){
		exponent_factor = 1.0E-27;
		exponent = -27;
	    }
	    if(Reale<1.0E30 && Reale>=1.0E27){
		exponent_factor = 1.0E27;
		exponent = 27;
	    }
	    if(Reale<1.0E-27 && Reale>=1.0E-30){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }
	    if(Reale>1.0E30){
		exponent_factor = 1.0E30;
		exponent = 30;
	    }
	    if(Reale<1.0E-30 && Reale > 0.0){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }
	    
		if(exponent == 0){
		MaestroG.superscripter("= "+sign+MaestroA.rounder(Reale/exponent_factor,3)+"","",
				   " "+unit_field,g,state.font10,x+state.s25,y);
		}
		else{
		MaestroG.superscripter("= "+sign+MaestroA.rounder(Reale/exponent_factor,3)+" x 10",""+exponent,
				   " "+unit_field,g,state.font10,x+state.s25,y);
		}
	}
	
	
	private void stringp(Graphics g){
	    String sign, sign2;
	    double exponent_factor, Reale;
	    int exponent;
	       
	    exponent_factor = 0.0;
	    exponent = 0;
	    
	    Reale = fieldfar;
	    
	    //Magnitude
	    if(Reale<1000.0 && Reale>=1.0 || Reale == 0.0){
		exponent_factor = 1.0;
		exponent = 0;
	    }
	    if(Reale<1.0 && Reale>=1.0E-3){
		exponent_factor = 1.0E-3;
		exponent = -3;
	    }
	    if(Reale<1.0E6 && Reale>=1.0E3){
		exponent_factor = 1.0E3;
		exponent = 3;
	    }
	    if(Reale<1.0E-3 && Reale>=1.0E-6){
		exponent_factor = 1.0E-6;
		exponent = -6;
	    }
	    if(Reale<1.0E9 && Reale>=1.0E6){
		exponent_factor = 1.0E6;
		exponent = 6;
	    }
	    if(Reale<1.0E-6 && Reale>=1.0E-9){
		exponent_factor = 1.0E-9;
		exponent = -9;
	    }
	    if(Reale<1.0E12 && Reale>=1.0E9){
		exponent_factor = 1.0E9;
		exponent = 9;
	    }
	    if(Reale<1.0E-9 && Reale>=1.0E-12){
		exponent_factor = 1.0E-12;
		exponent = -12;
	    }
	    if(Reale<1.0E15 && Reale>=1.0E12){
		exponent_factor = 1.0E12;
		exponent = 12;
	    }
	    if(Reale<1.0E-12 && Reale>=1.0E-15){
		exponent_factor = 1.0E-15;
		exponent = -15;
	    }
	    if(Reale<1.0E18 && Reale>=1.0E15){
		exponent_factor = 1.0E15;
		exponent = 15;
	    }
	    if(Reale<1.0E-15 && Reale>=1.0E-18){
		exponent_factor = 1.0E-18;
		exponent = -18;
	    }
	    if(Reale<1.0E21 && Reale>=1.0E18){
		exponent_factor = 1.0E18;
		exponent = 18;
	    }
	    if(Reale<1.0E-18 && Reale>=1.0E-21){
		exponent_factor = 1.0E-21;
		exponent = -21;
	    }
	    if(Reale<1.0E24 && Reale>=1.0E21){
		exponent_factor = 1.0E21;
		exponent = 21;
	    }
	    if(Reale<1.0E-21 && Reale>=1.0E-24){
		exponent_factor = 1.0E-24;
		exponent = -24;
	    }
	    if(Reale<1.0E27 && Reale>=1.0E24){
		exponent_factor = 1.0E24;
		exponent = 24;
	    }
	    if(Reale<1.0E-24 && Reale>=1.0E-27){
		exponent_factor = 1.0E-27;
		exponent = -27;
	    }
	    if(Reale<1.0E30 && Reale>=1.0E27){
		exponent_factor = 1.0E27;
		exponent = 27;
	    }
	    if(Reale<1.0E-27 && Reale>=1.0E-30){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }
	    if(Reale>1.0E30){
		exponent_factor = 1.0E30;
		exponent = 30;
	    }
	    if(Reale<1.0E-30 && Reale > 0.0){
		exponent_factor = 1.0E-30;
		exponent = -30;
	    }
	    
		if(exponent == 0){
		MaestroG.superscripter("=  "+MaestroA.rounder(Reale/exponent_factor,3)+"","",
				   " "+unit_field,g,state.font11,x+state.s40,y);
		}
		else{
		MaestroG.superscripter("=  "+MaestroA.rounder(Reale/exponent_factor,3)+" x 10",""+exponent,
				   " "+unit_field,g,state.font11,x+state.s40,y);
		}
	} 
}
   
