android mapview问题

时间:2011-05-24 06:54:52

标签: android android-mapview

在我的应用程序中,我正在使用地图视图,显示我当前位置附近的点。如果用户点击地图图钉我会显示有关该点的详细信息。显示详细信息我已经使用了一些动画部分。

当用户点击隐藏动画时我想再次显示上一张地图。为了显示动画我已经设置了内容视图,当用户点击隐藏动画时我再次从主要活动中调用该功能(来自创造)

所以当我调用该函数时,它会在mapview中给我空指针异常。 请帮忙!!!

这是我的代码

@Override
    protected void onCreate(Bundle icicle) {
        super.onCreate(icicle);

        //      searchButton=(Button)findViewById(R.id.searchId);
        //      searchButton.setOnClickListener(this);
        //      nearestButton=(Button)findViewById(R.id.nearestId);
        //      nearestButton.setOnClickListener(this);

        url1=ongetUrl();
        new FetchTask(FindFishActivity.this, url1).execute(null);
    }

    private class FetchTask extends AsyncTask<Object,Object,Object>
    {
        ProgressDialog progressDialog;
        Context ctx;
        String str_url;

        public FetchTask(Context mcontext,String str) 
        {
            this.ctx=mcontext;
            this.str_url=str;

        }

        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            progressDialog=ProgressDialog.show(FindFishActivity.this,"Loading Data","Please wait...");       
        }

        @Override
        protected Object doInBackground(Object... params) 
        {

            String res_str=onWebService(str_url);
            parse(res_str);

            return true;
        }

        @Override
        protected void onPostExecute(Object result) {
            super.onPostExecute(result);
            onMapDisplay();
            progressDialog.dismiss();
        }


public void onMapDisplay() {
        String lakeNameString;
        setContentView(R.layout.mapview);

        mapView=(MapView)findViewById(R.id.mapview);
//      if(mapView==null)
//      {
//          MapView view=new MapView(FindFishActivity.this,"0pPZGIF27HwAISdkPQhUWYj12n5N63e-vAbun1g");
//          setContentView(R.layout.mapview);
//      }

        mapView.setStreetView(true);
        mapView.setSatellite(false);
        mapController = mapView.getController();
        mapView.setBuiltInZoomControls(true);
        mapOverlays=mapView.getOverlays();
        drawable=FindFishActivity.this.getResources().getDrawable(R.drawable.pushpin4);
        myOverlays=new MyOverlays(drawable,FindFishActivity.this);
        for(int i=0;i<latitude.size();i++)
        {
            if(!latitude.get(i).equals("")) 
            {
                lat=Double.parseDouble(latitude.get(i));
                latitudearr.add(lat);
            }
        }
        for(int i=0;i<longitude.size();i++)
        {
            if(!longitude.get(i).equals(""))    
            {
                lon=Double.parseDouble(longitude.get(i));
                longitudearr.add(lon);
            }
        }
        for(int i=0;i<lakeNameList.size();i++)
        {
            if(!lakeNameList.get(i).equals(""))
            {
                lakeNameString=lakeNameList.get(i);
            }

        }


        for(int k=0;k<latitudearr.size();k++)
        {
            startPoint=new GeoPoint((int)(latitudearr.get(k) * 1E6),(int)(longitudearr.get(k) * 1E6));

            mapController.animateTo(startPoint);
            overlayItem=new OverlayItem(startPoint, ""+lakeNameList.get(k).toString(),""+lDescription.toString());
            myOverlays.addOverlay(overlayItem);
            mapOverlays.add(myOverlays);
            mapController.setZoom(6);
            mapView.invalidate();
        }

    }

并显示动画部分

public void onShowInfo() {

                setContentView(R.layout.tutorial5);
//                  LayoutInflater inflater=(LayoutInflater)FindFishActivity.this.getSystemService( Context.LAYOUT_INFLATER_SERVICE);
//                  View c=inflater.inflate(R.layout.tutorial5,(ViewGroup) findViewById(R.id.linearlayoutID));

                    transparentPanel=(TransparentPanel)findViewById(R.id.popup_window);
                    transparentPanel.setVisibility(View.VISIBLE);
                    transparentPanel.startAnimation(animShow);
                    final Button   hideButton = (Button)findViewById(R.id.hide_popup_button);
                    hideButton.setOnClickListener(new OnClickListener() {

                        public void onClick(View v) {
                            transparentPanel.startAnimation(animHide);
                            transparentPanel.setVisibility(View.GONE);
                            String s=FindFishActivity.this.ongetUrl();
                            new FetchTask(FindFishActivity.this,s).execute(null);

                        }

                    });

1 个答案:

答案 0 :(得分:0)

我不认为你有必要创建单独的布局,即。 tutorial5

还有其他方法可供选择。在mapview添加相对布局中,将tutorial5内容放在具有透明度的所有内容中。

Result:您将获得带有tutorial5布局的mapview。只需在开头隐藏它。当用户点击pin时,只需将可见性设置为View.VISIBLE,然后点击停止后将其恢复为View.GONE

此地图仍然有效,您也可以在动画顶部时导航。效果很好。

P.S:将您的布局tutorial5背景颜色设置为#80000000 i.e transparent black。我个人喜欢.. :))