Gmap.net标记删除

时间:2015-05-27 16:05:07

标签: c# sqlite marker gmap.net

我正在使用GMap.NET代码来处理地图和标记。添加标记并对地图执行任何操作都不是从地图中删除单个标记的问题。我在Google上随处搜索从地图中删除标记,但删除标记似乎不是一个热门话题。

以下是我用来添加代码的代码段。

        private void AddMarker_ButtonClick(object sender, AddMarkerEventArgs e)
    {
        DBDictAdd("Marker", " ",e.Latitude, e.Longitude, true, "192.168.1.1");
        m_dbMarkers.Insert(_table, dbmarkertable);
        dbmarkertable.Clear();
        GMarkerGoogle marker = new GMarkerGoogle(new PointLatLng(e.Latitude, e.Longitude),
              GMarkerGoogleType.green);
        marker.ToolTip = new GMapRoundedToolTip(marker);
        marker.ToolTipMode = MarkerTooltipMode.OnMouseOver;
        marker.Tag = MarkerIndex;
        marker.ToolTipText = (marker.Position.ToString());
        markersOverlay.Markers.Add(marker);
        MarkerIndex++;
    }

如您所见,我正在使用SQLiteID和其他信息存储到数据库中以供标记使用。我正在使用数据库方法,因为我需要使用标记位置存储更多信息。这部分代码可以工作。

我遇到的问题是调用标记信息,以便我可以将其删除。我知道这两个电话存在。

markersOverlay.Markers.Remove();
markersOverlay.Markers.RemoveAt();

我已经使用了removeAt命令,但我必须手动执行,并注意到使用removeAt(0)命令每次从该数组的第一个条目获取它。

这是我到目前为止所尝试的:

private void uxRemoveMarkerButton_Click(object sender, EventArgs e)
        {
            MessageBox.Show("Select the marker to remove.");
            uxGmap.OnMarkerClick += new MarkerClick(uxGmap_OnMarkerClick);

        }

        private void uxGmap_OnMarkerClick(object sender, EventArgs e)
        {
            //int? mID = null;
            //DataTable da = m_dbMarkers.GetDataTable("SELECT * from markers");
            //GMapMarker marker = null;
            //PointLatLng p = new PointLatLng(lat, lng);
            //foreach (GMapMarker m in markersOverlay.Markers)
            //{
            //    if (m.Position == p)
            //        marker = m;
            //}
            //markersOverlay.Markers.Remove(marker);
            //MessageBox.Show("done");
            //foreach (DataRow dr in da.Rows)
            //{
            //    if (Convert.ToDouble(dr[3]) == lat)
            //    {
            //        MessageBox.Show(dr[3].ToString());
            //        //mID = Convert.ToInt32(dr[0]);
            //    }
            //}
            //markersOverlay.Markers.IndexOf(marker);

            //mID= Convert.ToInt32(m_dbMarkers.ExecuteScalar("SELECT ID FROM markers"));
            //m_dbMarkers.Delete(_table, String.Format("markers.ID = {0} ", mID));
            //markersOverlay.Markers.RemoveAt(mID);
            //MessageBox.Show(mID.ToString());
            uxGmap.OnMarkerClick -= new MarkerClick(uxGmap_OnMarkerClick);

        }

当我点击它以实际将其从地图中删除时,有关如何获取标记ID或标记本身的任何建议或指导?

修改 我更新了AddMarker_ButtonClick

1 个答案:

答案 0 :(得分:2)

我发现从地图中删除标记的解决方案:

GMap.Net有一个MarkerClick事件,您可以订阅。在我的表单中,这是我使用的代码以及我将其放在表单代码中的位置。

Public Form1()
    {
            uxGmap.OnMarkerClick += new MarkerClick(uxGmap_OnMarkerClick);
    }

uxGmap_OnMarkerClick

中的代码
private void uxGmap_OnMarkerClick(GMapMarker item, MouseEventArgs e)
    {
        currentMarker = item;
        uxRemoveMarkerButton.Enabled = true;
    }

我有一个名为GMapMarker的全局currentMarker,用于存储您点击的item标记。我还启用了按钮来删除表单上的标记。

然后我使用单击按钮从地图中删除标记:

private void uxRemoveMarkerButton_Click(object sender, EventArgs e)
    {
            int? mID = null;
            if(currentMarker != null)
            {
                mID = Convert.ToInt32(currentMarker.Tag);
                markersOverlay.Markers.Remove(currentMarker);
                currentMarker = null;
            }
            m_dbMarkers.Delete(_table, String.Format("markers.ID = {0} ", mID));
            uxRemoveMarkerButton.Enabled = false;
     }

GMapMarker具有Tag属性,我可以将标记ID存储到标记中。然后,我从全局currentMarker.Tag中提取该ID,并将其存储到本地int mID。我使用这个mID来删除存储在我拥有的sqlite数据库中的标记ID的行。我也禁用该按钮,在单击标记之前不允许任何用户错误。