¿Cómo puedo convertir coordenadas X e Y en el gráfico diagrama de píxeles en una interfaz gráfica de usuario

Krystian Rusin:

Estoy creando un programa para un GUI casco convexo que se muestra en una cuadrícula. El código siguiente es la interfaz gráfica de usuario.

public class Plot extends JPanel{
    private int width = 1025;
    private int height = 500;
    private int padding = 50;
    private int labelPadding = 50;
    private Color lineColor = new Color(44, 102, 230, 180);
    private Color pointColor = new Color(100, 100, 100, 180);
    private Color gridColor = new Color(200, 200, 200, 200);
    private static final Stroke GRAPH_STROKE = new BasicStroke(2f);
    private int pointWidth = 4;
    private int numberYDivisions = 10;
    private Vector<Point> convexHull;
    private static DecimalFormat df = new DecimalFormat("0.00");
    private Point[] point;

    public Plot(Point[] point, Vector convexHull) {
        this.point=point;
        this.convexHull=convexHull;
    }

    @Override
        protected void paintComponent(Graphics g){
            super.paintComponent(g);
            Graphics2D g2 = (Graphics2D) g;

            double xScale = (maxX(point)+10)*2;
            double yScale = (maxY(point)+10)*2 ;
            List<Point> graphPoints =  new ArrayList<>();

            for(Point temp : convexHull){
                double x1 = temp.x;
                double y1 = temp.y;
                graphPoints.add(new Point(x1,y1));
            }

            double intervalY;
            intervalY = maxY(point)/5;

            g2.setColor(Color.WHITE);
            g2.fillRect(padding + labelPadding, padding, (int)xScale, (int)yScale);


            //Hatch marks for Y
        for(int i = 0;i<numberYDivisions/2;i++){
            if(point.length>0){
                g2.setColor(gridColor);
                g2.drawLine(padding+(100*i), padding, padding+(100*i), 1000);
                g2.setColor(Color.BLACK);
                String yLabel = df.format(maxY(point) - (intervalY * i)) + "";
                g2.drawLine(495, padding + (100 * i), 505, padding + (100 * i));
                g2.drawString(yLabel, 460, padding + (100 * i));

            }
        }
        for(int i = 0;i<=numberYDivisions/2;i++){
            if(point.length>0){
                g2.setColor(gridColor);
                g2.drawLine(500+padding+(100*i), padding, 500+padding+(100*i), 1000);
                g2.setColor(Color.BLACK);
                if(i!=0) {
                    String yLabel = df.format(0 - (intervalY * i)) + "";
                    g2.drawLine(495, 500 + (100 * (i)) - padding, 505, 500 + (100 * (i)) - padding);
                    g2.drawString(yLabel, 460, 500 + (100 * (i)) - padding);
                }
            }
        }

        Double intervalX;
        intervalX = maxX(point)/5;
        //Hatch marks and grid lines for x;
        for(int i = 0;i<numberYDivisions/2;i++){
            if(point.length>0){
                g2.setColor(gridColor);
                g2.drawLine(padding,padding+(100*i),1000,padding+(100*i));
                g2.setColor(Color.BLACK);
                String yLabel = df.format(-maxX(point) + (intervalX * i)) + "";
                g2.drawLine(padding + (100 * i), 495, padding + (100 * i), 505);
                g2.drawString(yLabel, padding + (100 * i), 480);
            }
        }
        for(int i = 0;i<=numberYDivisions/2;i++){
            if(point.length>0){
                g2.setColor(gridColor);
                g2.drawLine(padding,500+padding+(100*i),1000,500+padding+(100*i));
                if(i!=0) {
                    g2.setColor(Color.BLACK);
                    String yLabel = df.format(0 + (intervalX * i)) + "";
                    g2.drawLine(500 + (100 * i) - padding, 495, 500 + (100 * i) - padding, 505);
                    g2.drawString(yLabel, 500 + (100 * i) - padding, 480);
                }
            }
        }
        //x axis
        g2.drawLine(padding, 500, 1025-padding, 500);
        //y axis
        g2.drawLine(500,padding,500,1025-padding);



    }

    private double maxX(Point[] p){
        Double Max = Double.MIN_VALUE;
        for(int i = 0;i<p.length;i++){
            if(Max<p[i].x){
                Max = p[i].x;
            }
        }
        return Max;
    }

    private double minX(Point[] p){
        Double min = Double.MAX_VALUE;
        for(int i = 0;i<p.length;i++){
            if(min>p[i].x){
                min = p[i].x;
            }
        }
        return min;
    }

    private double maxY(Point[] p){
        Double Max = Double.MIN_VALUE;
        for(int i = 0;i<p.length;i++){
            if(Max<p[i].y){
                Max = p[i].y;
            }
        }
        return Max;
    }

    private double minY(Point[] p){
        Double min = Double.MAX_VALUE;
        for(int i = 0;i<p.length;i++){
            if(min>p[i].y){
                min = p[i].y;
            }
        }
        return min;
    }

En el código anterior los puntos se leen desde un archivo CSV y de información [] con una propiedades x e y almacenados. Para este gráfico que se muestra correctamente, las marcas de sombreado se calculan sobre la base de los valores en el punto []. Pero no estoy seguro de cómo trazar cada punto porque la creación de un óvalo tiene coordenadas X e Y para los píxeles en la pantalla, no puedo simplemente usar las coordenadas X e Y de cada punto como coordenadas X e Y de los puntos. ¿Hay una manera de convertir las coordenadas X e Y en el punto [] para pixel coordenadas X e Y? Cualquier ayuda es apreciada.

WJS:

Es necesario para escalar hacia arriba o hacia abajo basado en el max x and y of your datay la width and height, respectivamente, de supanel.

Si su data xx es máxima xmaxy su panel widthes pwidthentonces usted necesita para multiplicar sus data xcoordenadas por pwidth/xmax. Hacerlo utilizando doubletipos continuación, convertir a intsi es necesario.

Supongo que te gusta

Origin http://10.200.1.11:23101/article/api/json?id=404205&siteId=1
Recomendado
Clasificación