在android中绘制不同点的图

时间:2012-07-21 07:43:48

标签: android

我从数据库中获得了一些点(A,B),并希望绘制这些点并将它们连接起来形成一个多边形类型的形状。基本上它将代表游泳池盖的形状。现在我已经编写了以下代码但是结果是weired.Only最后绘制的线存在,之前绘制的线消失。我做错了什么?或者有更好的方法吗?

      private void calculationForPlot(){
     ArrayList<String> al_edit_A_ft = new ArrayList<String>();

     ArrayList<String> al_edit_A_inch=new ArrayList<String>();
     ArrayList<String>al_edit_B_ft=new ArrayList<String>(); 
     ArrayList<String>al_edit_B_inch= new ArrayList<String>();
    float x=0;
     AndroidOpenDbHelper androidOpenDbHelperObj = new AndroidOpenDbHelper(this);
        SQLiteDatabase sqliteDatabase = androidOpenDbHelperObj.getReadableDatabase();
        String q="SELECT * FROM ab_measurement WHERE job_id=" +"\""+Settings.jobid +"\"";


   Cursor  cursor = sqliteDatabase.rawQuery(q,null);

        if (cursor.moveToNext()) {
            System.out.println(cursor.getCount());
        int m=Integer.parseInt(cursor.getString(4));

            do {
                try{

                float a = 0,b = 0;



                 a=(float) Double.parseDouble(cursor.getString(6));
                 String number =String.valueOf(a);
                 System.out.println("aaa ggg"+number);
                 String int_part =number.substring(0,number.indexOf("."));
                 String float_part=number.substring(number.lastIndexOf(".")+1,number.length());
                 System.out.println("aaa values"+int_part);
                 System.out.println("aaa values"+float_part);


                  al_edit_A_ft.add(int_part);
                  al_edit_A_inch.add(float_part);

                     b= (float) Double.parseDouble(cursor.getString(7));
                     String number_b =String.valueOf(b);
                     System.out.println("aaa ggg"+number_b);
                     String int_part_b =number_b.substring(0,number_b.indexOf("."));
                     String float_part_b=number_b.substring(number_b.lastIndexOf(".")+1,number_b.length());
                     System.out.println("aaa values"+int_part_b);
                     System.out.println("aaa values"+float_part_b);
                     al_edit_B_ft.add(int_part_b);
                     al_edit_B_inch.add(float_part_b);

                     x= (float) Double.parseDouble(cursor.getString(3));
                     String ft_base =String.valueOf(x);
                     System.out.println("aaa ggg"+ft_base);
                     String int_part_ft =ft_base.substring(0,ft_base.indexOf("."));
                     String float_part_inch=ft_base.substring(ft_base.lastIndexOf(".")+1,ft_base.length());
                     System.out.println("aaa values"+int_part_ft);
                     System.out.println("aaa values"+float_part_inch);


                }
                catch (Exception e) {

                }

            } while (cursor.moveToNext());

    if(m>0){
        float pixelPerUnit=240/x;

        if(x>0){
            float X_prev=110;
            float Y_prev=250;
            float X = 0;
            float Y = 0;

            drawPlot(X_prev,Y_prev, X_prev+1, Y_prev+1);//origin
            for(int i=0;i</*obj.*/m;i++){
                String str_pointA=al_edit_A_ft.get(i).concat(".").concat(al_edit_A_inch.get(i));
                float pointA= (float) (Double.parseDouble(str_pointA)*pixelPerUnit);

                String str_pointB=al_edit_B_ft.get(i).concat(".").concat(al_edit_B_inch.get(i));
                float pointB=(float) (Double.parseDouble(str_pointB)*pixelPerUnit);

                float d = 240;
                if (pointB<1) {
                    X =  (110+(pointA/2));
                }
                else if (pointA<1){
                    Y = (110-(pointB/2));
                }else{
                     float a = (pointA * pointA - pointB * pointB + d * d ) / (2 * d);
                      float h = (float) Math.abs(Math.sqrt( pointA * pointA - a * a ));

                        if (h<0){
                            h=0;
                        }

                        X  = (110+(a/2)) ;
                        Y  =  (250-h);   
                      }

                System.out.println("X and Y"+"  "+X+"  "+Y);
                      drawPlot(X_prev+1, Y_prev_+1, X, Y);


                       X_prev=X;
                       Y_prev=Y;
                    }

            drawPlot(X_prev, Y_prev, 110, 250);//to complete the loop

            }

        }
    }
    }

        private void drawPlot(float startX,float startY,float endX,float endY) {
    System.out.println("Draw plot called");
     bitmap = Bitmap.createBitmap((int) getWindowManager()
                .getDefaultDisplay().getWidth(), (int) getWindowManager()
                .getDefaultDisplay().getHeight(), Bitmap.Config.ARGB_8888);
            Canvas canvas = new Canvas(bitmap);
            drawingImageView.setImageBitmap(bitmap);


            Paint paint = new Paint();
            paint.setColor(Color.BLUE);
            paint.setStrokeWidth(2);

            canvas.drawLine(startX, startY, endX, endY, paint);


}

1 个答案:

答案 0 :(得分:0)

你可以使用Bresenham的线算法从点a到b绘制线 - 这是一个非常简单的算法。这是在Lua

function line(x0,y0,x1,y1)
    local plots={}
    local steep=math.abs(y1-y0)>math.abs(x1-x0)
    if steep then
        x0,y0=y0,x0
        x1,y1=y1,x1
    end
    if x0>x1 then
        x0,x1=x1,x0
        y0,y1=y1,y0
    end
    local dx,dy=x1-x0,math.abs(y1-y0)
    local error=dx/2
    local y=y0
    local sy=(y0<y1 and 1 or -1)
    for x=x0,x1 do
        if steep then
            table.insert(plots,{y,x})
        else
            table.insert(plots,{x,y})
        end
        error=error-dy
        if error<0 then
            y=y+sy
            error=error+dx
        end
    end
    return plots
end