проблема просмотра карты Android

1

в моем приложении я использую представление карты, которое показывает пятна рядом с моим текущим местоположением. Если пользователь нажимает на карту, то я показываю подробную информацию об этом месте. Для отображения деталей я использовал некоторую часть анимации.

когда пользователь нажимает на скрыть анимацию, я хочу снова показать предыдущую карту. Для показа анимации я установил представление контента и снова, когда пользователь нажимает на скрытую анимацию, я вызываю функцию из основного действия ( from on create)

поэтому, когда я вызываю эту функцию, она дает мне исключение null-указателя в 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);

                        }

                    });
Теги:
android-mapview

1 ответ

0

Я не думаю, что вам необходимо создать отдельный макет, т.е. tutorial5.

Для вас существует другой способ. В mapview добавьте относительный макет и поместите tutorial5 содержимое с прозрачностью и всем этим.

Result: Вы получите mapview с макетом tutorial5 сверху. Просто спрячь его в начале. когда пользователь нажимает на контакт, только установите видимость на View.VISIBLE, и после нажатия кнопки stop верните его на View.GONE.

С этой картой все еще будет активна, и вы сможете перемещаться также при анимации сверху. Дает хороший эффект.

P.S: установите цвет фона tutorial5 на #80000000 i.e transparent black. Мне это нравится..:)

Ещё вопросы

Сообщество Overcoder
Наверх
Меню