谷歌地图Android指向多边形

时间:2014-10-27 14:19:32

标签: android google-maps polygon

我创建了一个使用谷歌地图android api的Android应用程序 这个应用程序需要有一个单击多边形功能,但因为它不适用于谷歌地图android api v2。我做了一些研究,找到了解决这个功能的方法 我最终得到的是检查一个点是否在多边形方法中 我正在使用这个library。如果手动创建边界,它的效果非常好 如果可以在循环中创建可以解决我的问题的界限 我从我的数据库中获得了多边形点。

这是我的MapFragment代码:

public class MapBlocksMapView extends Fragment {

    protected GoogleMap googleMap;
    protected LatLng latLng;
    protected Intent intent;
    protected String color, crops, block_code, tmp_user;

    public MapBlocksMapView() {
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        ActionBar actionBar = getActivity().getActionBar();
        actionBar.setTitle("Block View");
        View rootView = inflater.inflate(R.layout.fragment_blocksmapview, container, false);

        if (googleMap== null) {
            googleMap= ((SupportMapFragment) getChildFragmentManager().findFragmentById(R.id.map)).getMap();
        }

        Bundle bundle = getArguments();
        if (bundle != null) {
            block_code = bundle.getString("block_code");
            tmp_user = bundle.getString("user");
        }

        googleMap.setOnMapClickListener(new GoogleMap.OnMapClickListener() {
            @Override
            public void onMapClick(LatLng latLng) {
                checkpoint(latLng.latitude, latLng.longitude);
            }
        });
        return rootView;

    }

    @Override
    public void onActivityCreated(Bundle savedInstanceState){
        getdata(getActivity(), block_code);
        super.onActivityCreated(savedInstanceState);
    }

    private void checkpoint(double latitude, double longitude) {

        System.out.println(latitude +"," +longitude);
    }

    public void getdata(Context ctx, String block_code) {

        SQLHelper dbhelper = new SQLHelper(ctx);
        dbhelper.getReadableDatabase();

        JSONArray jsonArray = dbhelper.getSingleBlocks(block_code);

        try {
            for (int a = 0; a < jsonArray.length(); a++) {

                JSONObject jsonObject = new JSONObject(String.valueOf(jsonArray.getJSONObject(a)));
                JSONArray jsonArray1 = jsonObject.getJSONArray("b_points");
                if (jsonObject.getJSONArray("b_points").length() > 0) {
                    color = jsonObject.getString("b_color");
                    crops = jsonObject.getString("b_crop");
                    PolygonOptions rectOptions = new PolygonOptions();

                    for (int b = 0; b < jsonArray1.length(); b++) {
                        JSONArray jsonArray2 = jsonArray1.getJSONArray(b);

                        rectOptions.add(new LatLng(jsonArray2.getDouble(0), jsonArray2.getDouble(1)));


                        System.out.println(jsonArray2.get(0) + " / " + jsonArray2.get(1));

                    }
                    latLng = new LatLng(jsonArray1.getJSONArray(0).getDouble(0), jsonArray1.getJSONArray(0).getDouble(1));
                    rectOptions.strokeWidth(1).strokeColor(Color.parseColor(color)).fillColor(Color.parseColor(color));
                    googleMap.addPolygon(rectOptions);
                    CameraUpdate cameraPosition = CameraUpdateFactory.newLatLngZoom(latLng, 17);
                    googleMap.animateCamera(cameraPosition);

                } else {

                    Toast.makeText(getActivity(), "Error with the selected block", Toast.LENGTH_LONG).show();
                    closeFragment();
                }
            }
        } catch (JSONException e) {
            e.printStackTrace();
        }

    }

    @Override
    public void onDestroyView() {
        super.onDestroyView();
        SupportMapFragment f = (SupportMapFragment) getFragmentManager()
                .findFragmentById(R.id.map);
        if (f != null)
            getFragmentManager().beginTransaction().remove(f).commit();
    }

    private void closeFragment() {
        getActivity().getFragmentManager().popBackStack();
    }

}

以下是来自库的示例代码:

Polygon polygon = Polygon.Builder()
    .addVertex(new Point(1, 3))
    .addVertex(new Point(2, 8))
    .addVertex(new Point(5, 4))
    .addVertex(new Point(5, 9))
    .addVertex(new Point(7, 5))
    .addVertex(new Point(6, 1))
    .addVertex(new Point(3, 1))
    .build();

Point point = new Point(4.5f, 7);
boolean contains = polygon.contains(point);

如果有人有其他解决方案或建议会有所帮助 谢谢

3 个答案:

答案 0 :(得分:0)

我也有同样的问题,但我没有找到解决这个问题的“好”解决方案。

最后,我将所有多边形保存在列表中,并使用点击位置迭代它。 (但要注意;也许你在这个位置有多个多边形)

答案 1 :(得分:0)

好吧,这个图书馆不会有太大的帮助,因为你有地理位置,图书馆需要屏幕位置,所以你将自己做大部分的工作。

你需要通过获取地图投影来获取每个latlng并将它们转换为屏幕点

Point point = googleMap.getProjection().toScreenLocation(myLatLngPoint);

然后你可以在循环时将这一点放入你的库中。但是我不知道如果您使用的latlng不在投影中(即屏幕外)会返回什么,所以你必须测试

答案 2 :(得分:0)

我设法在一些挖掘后解决这个问题,并在github上找到了这个代码 我现在正在使用这个library,它就像一个魅力。

我的多边形点在我的数据库中以字符串形式存储。

[[3.65E-4,-1.1E-5],[-5.0E-6,3.54E-4],[-3.0E-6,-1.1E-4]]

这是一个示例代码

protected double[] points;

public void getdata(){

    SQLHelper dbhelper = new SQLHelper(ctx);
    dbhelper.getReadableDatabase();

    String[] ls =dbhelper.getSingleBlocksPointsArray(block_code)
                .replaceAll("\\[", "")
                .replaceAll("\\]","")
                .split(",");
    points = new double[ls.length];
    for(int i=0;i<ls.length;i++)
    {

        points[i] = Double.parseDouble(ls[i]);
    }
}

在onCreateView上我用这个:

googleMap.setOnMapClickListener(new GoogleMap.OnMapClickListener() {
    @Override
    public void onMapClick(LatLng latLng) {
        if(contains(new Coordinate(latLng.latitude,latLng.longitude), points)) {
            Toast.makeText(getActivity(),"True",Toast.LENGTH_SHORT).show();
        }else {
            Toast.makeText(getActivity(),"False",Toast.LENGTH_SHORT).show();
        }
    }
});
相关问题