微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

android mapview问题

如何解决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);

                        }

                    });
    

解决方法

我认为您不必创建单独的布局,即。
tutorial5
。 您还有其他选择。在您的
mapview
中添加相对布局,并在其中添加
tutorial5
内容并保持透明。
Result:
您将获得view2ѭ布局在顶部的mapview。刚开始就隐藏它。当用户单击图钉时,只需将可见性设置为
View.VISIBLE
,然后单击停止位置即可将其恢复为
View.GONE
。 使用此地图仍将处于活动状态,并且当动画位于顶部时,您也可以导航。效果不错。 P.S:将布局“ 2”的背景色设置为“ 10”。我个人喜欢.. :)     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。