- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在此处找到的 bing map 示例多边形搜索有点问题:
Polygon search is about halfway down this link.
public bool polygonSearch(LocationCollection points, double lat, double lon)
{
MapPolygon poly = new MapPolygon();
int i = 0;
int j = points.Count - 1;
bool inPoly = false;
for (i = 0; i < points.Count; i++)
{
if (points[i].Longitude < lon && points[j].Longitude >= lon || points[j].Longitude < lon && points[i].Longitude >= lon)
{
if (points[i].Latitude + (lon - points[i].Longitude) / (points[j].Longitude - points[i].Longitude) * (points[j].Latitude - points[i].Latitude) < lat)
{
inPoly = !inPoly;
}
}
j = i;
}
return inPoly;
}
我使用 ViewportPointToLocation
获取鼠标坐标并在鼠标单击时添加一个图钉。
Point mousePosition = e.GetPosition(myMap);
Microsoft.Maps.MapControl.WPF.Location pinLocation = myMap.ViewportPointToLocation(mousePosition);
// Convert the mouse coordinates to a location on the map
// The pushpin to add to the map.
Pushpin pin = new Pushpin();
pin.Location = pinLocation;
pin.Content = "Cust";
pin.Heading = 0;
// Adds the pushpin to the map
myMap.Children.Add(pin);
这是我使用多边形搜索来查看我是否在多边形内单击的地方。
polygonSearch(polygon.Locations, pin.Location.Latitude, pin.Location.Longitude))
如下图所示,我将标签设置为“配送区域内”或“区域外的客户”,具体取决于天气 polygonSearch 返回 true 或 false。
在处理多边形的边缘时似乎不起作用。有更多经验的人可以告诉我哪里错了吗?
下面是完整的代码示例:
您需要引用 Microsoft.Maps.MapControl.WPF.dll
让这个工作。
我只制作了一个演示,其中包含 bing map 控制 map 、一个告诉我们多边形搜索输出的标签,以及一个允许您在多边形内搜索的复选框。
要制作多边形,只需右键单击要绘制的 map ,然后按“Escape”结束绘制多边形。然后您可以单击“通过左键单击搜索地址”复选框并在多边形内搜索。
正如您将看到的,当我们看到我们在刚刚绘制的多边形内单击时,来自 MSDN 的多边形搜索返回区域外!
主窗口.xaml
<Window x:Class="PolygonSearch.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:m="clr-namespace:Microsoft.Maps.MapControl.WPF;assembly=Microsoft.Maps.MapControl.WPF"
Title="MainWindow" Height="350" Width="525" KeyDown="Window_KeyDown">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="100*"/>
</Grid.RowDefinitions>
<StackPanel>
<Label Content="Label" Height="28" HorizontalAlignment="Left" Margin="10,10,0,0" Name="lbl_arearsult" Grid.Row="0" VerticalAlignment="Top" />
<CheckBox Content="Search Address by left click" Height="16" HorizontalAlignment="Left" Margin="10,10,0,0" Name="chk_search" VerticalAlignment="Top" />
</StackPanel>
<m:Map x:Name="myMap" Grid.Row="1" CredentialsProvider="your_bing_map_key" Mode="AerialWithLabels" MouseLeftButtonDown="myMap_MouseDown" MouseRightButtonDown="myMap_MouseRightButtonDown" KeyDown="myMap_KeyDown" />
</Grid>
</Window>
主窗口.xaml.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using Microsoft.Maps.MapControl.WPF;
namespace PolygonSearch
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
LocationCollection drawPolyPoints = new LocationCollection();
public MainWindow()
{
InitializeComponent();
}
public bool polygonSearch(LocationCollection points, double lat, double lon)
{
MapPolygon poly = new MapPolygon();
int i = 0;
int j = points.Count - 1;
bool inPoly = false;
for (i = 0; i < points.Count; i++)
{
if (points[i].Longitude < lon && points[j].Longitude >= lon || points[j].Longitude < lon && points[i].Longitude >= lon)
{
if (points[i].Latitude + (lon - points[i].Longitude) / (points[j].Longitude - points[i].Longitude) * (points[j].Latitude - points[i].Latitude) < lat)
{
inPoly = !inPoly;
}
}
j = i;
}
return inPoly;
}
private void myMap_KeyDown(object sender, KeyEventArgs e)
{
if (e.Key == System.Windows.Input.Key.Escape)
{
MapPolygon polygon = new MapPolygon();
polygon.Fill = new System.Windows.Media.SolidColorBrush(System.Windows.Media.Colors.Blue);
polygon.Stroke = new System.Windows.Media.SolidColorBrush(System.Windows.Media.Colors.Green);
polygon.StrokeThickness = 5;
polygon.Opacity = 0.7;
polygon.Locations = drawPolyPoints;
polygon.Tag = "1388_q3_polygon_5";
myMap.Children.Add(polygon);
//drawPolyPoints.Clear();
for (int p = 0; p < myMap.Children.Count; p++)
{
object entity = myMap.Children[p];
if (entity is Microsoft.Maps.MapControl.WPF.Pushpin)
{
if (((Microsoft.Maps.MapControl.WPF.Pushpin)entity).Content.ToString() == "Vertice")
myMap.Children.Remove(((Microsoft.Maps.MapControl.WPF.Pushpin)entity));
}
}
}
}
private void myMap_MouseDown(object sender, MouseButtonEventArgs e)
{
if (chk_search.IsChecked == true)
{
Point mousePosition = e.GetPosition(myMap);
Microsoft.Maps.MapControl.WPF.Location pinLocation = myMap.ViewportPointToLocation(mousePosition);
// Convert the mouse coordinates to a location on the map
// The pushpin to add to the map.
Pushpin pin = new Pushpin();
pin.Location = pinLocation;
pin.Content = "Cust";
pin.Heading = 0;
// Adds the pushpin to the map
myMap.Children.Add(pin);
bool inArea = false;
for (int p = 0; p < myMap.Children.Count; p++)
{
object entity = myMap.Children[p];
if (entity is Microsoft.Maps.MapControl.WPF.MapPolygon)
{
if (polygonSearch(((Microsoft.Maps.MapControl.WPF.MapPolygon)entity).Locations, pin.Location.Latitude, pin.Location.Longitude))
{
string[] quadAttributes = ((Microsoft.Maps.MapControl.WPF.MapPolygon)entity).Tag.ToString().Split('_');
lbl_arearsult.Content = "Within delivery area ";
inArea = true;
break;
}
else
{
inArea = false;
}
}
}
if (inArea != true)
lbl_arearsult.Content = "Customer out of area. ";
}
}
private void myMap_MouseRightButtonDown(object sender, MouseButtonEventArgs e)
{
Point mousePosition = e.GetPosition(myMap);
Microsoft.Maps.MapControl.WPF.Location pinLocation = myMap.ViewportPointToLocation(mousePosition);
// Convert the mouse coordinates to a location on the map
// The pushpin to add to the map.
Pushpin pin = new Pushpin();
pin.Location = pinLocation;
pin.Content = "Vertice";
// Adds the pushpin to the map
myMap.Children.Add(pin);
drawPolyPoints.Add(pin.Location);
}
private void Window_KeyDown(object sender, KeyEventArgs e)
{
myMap_KeyDown(sender, e);
}
}
}
注意:此设计仅适用于创建 1 个多边形进行搜索,但您仍然可以直观地看到我的多边形搜索失败的地方。
编辑:
非常感谢KeyboardP,我们发现如果完全放大,然后绘制多边形,然后搜索,问题就不存在了。但是如果我们绘制它,然后缩放,我们会看到同样的问题出现。
我也已经调试确认LocationCollection多边形在不同的缩放级别是一样的
列表项
最佳答案
我大约 6 年前写了这篇文章。这是基于标准二维几何的多边形算法中的一个简单点,不是地理空间精确算法。它适用于覆盖城市或更小区域的小多边形。大的多边形看起来不太准确。请注意, map 上两点之间的线,即使它看起来是直的,但实际上是弯曲的。一个很好的例子可以在这里找到:http://alastaira.wordpress.com/2011/06/27/geodesics-on-bing-maps-v7/
至于您的问题,如果您想单击多边形,只需使用鼠标事件即可。如果你想检查一个点是否在多边形中,那么你可以使用 WPF 中强大的 SQL 空间库,它将在多边形计算中为你提供地理空间上准确的点。您不需要连接到数据库。您只需要通过 SQL Express 免费获得的 Microsoft.SqlServer.Types.dll。您可以在 .NET 中和 Bing Maps WPF 控件中使用它。这是一个很好的起点:http://ecn.channel9.msdn.com/o9/learn/SQL2008R2TrainingKit/Labs/UsingSpatialDataInManagedCode/Lab.docx
完成此操作后,您可以简单地从多边形创建一个 SQLGeography 对象并检查您的点是否与多边形相交。
关于c# - Bing map 多边形搜索不准确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17371801/
我正在尝试从一个 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 m
我是 Haskell 的新手,我认为函数 map map和 map.map在 Haskell 中是一样的。 我的终端给了我两种不同的类型, (map.map) :: (a -> b) -> [[a]
我的目标是创建一个 map 的 map ,这样我就可以通过它的键检索外部 map 的信息,然后通过它们的键访问它的“内部” map 。 但是,当我得到每个内部映射时,我最初创建的映射变成了一个对象,我
如何使用 Java8 编写以下代码? for (Entry> entry : data.entrySet()) { Map value = entry.getValue(); if (valu
我有覆盖整个南非的图片。它们为Tiff格式,并已将坐标嵌入其中。我正在尝试拍摄这些图像(大约20张图像),并将它们用作我的iPhone应用程序中的地图叠加层。我的问题在于(准确地)将地图切成图块。 我
所以我有 2 std::map s >一个是“旧的”,一个是“新的”,我想知道哪些文件被删除了,这样就能够遍历差异并对 shared_ptr 做一些事情。这样的事情可能吗?如何做到? 最佳答案 虽然
是否可以将当前查看的 google.maps.Map 转换为静态图像链接,以便我可以获取图像并将其嵌入到 PDF 中? 我在 map 上添加了一些带有自定义图标的标记,所以我不确定这是否真的可行。 如
你能帮我吗 Java Streams ? 从标题可以看出我需要合并List>>进入Map> . 列表表示为List>>看起来像: [ { "USER_1":{
对于 idAndTags 的第二个条目,内部映射被打乱,但第一个条目则不然 第一次接近! for (Map.Entry> entryOne : idAndTags.entrySet()) {
我将从我的代码开始,因为它应该更容易理解我想要做什么: @function get-color($color, $lightness) { @return map-get(map-get($col
我过去曾在许多网站上使用过 Google map ,但遇到了以前从未遇到过的问题。 map 窗口正在显示,但它只显示左上角的 map 片段,以及之后的任何内容(即使我在周围导航时),右侧也不会加载任何
众所周知,这些 map ,无论是常规街道 map 还是卫星 map ,在中国的特定地区都无法正确排列。那么哪个 map 排列正确,是卫星 map 还是默认街道 map ?一些网站表明卫星 map 是正
在拖尾事件之后,我面临着获取此处 map 中的 map 边界的问题。我需要新的经纬度来在新更改的视口(viewport)中获取一些项目/点。我只是想在拖动结束时获得谷歌地图map.getBounds(
我想做的是通过 ajax API 显示以英国邮政编码为中心的小型 bing 生成 map 。我相信这是可能的;我在 Bing map 文档中找不到如何将英国邮政编码转换为可以插入 map Ajax 控
我有一个 List我想转换成的 e Map>其中外部字符串应为“Name”,内部字符串应为“Domain”。 Name Id Domain e(0) - Emp1, 1, Insuran
我的第 2 部分:https://stackoverflow.com/questions/21780627/c-map-of-maps-typedef-doubts-queries 然后我继续创建 I
是否可以在 1 行中使用 Java8 编写以下所有 null 和空字符串检查? Map> data = new HashMap<>(holdings.rowMap()); Set>> entrySet
我正在审查一个项目的旧代码,并使用 Map 的 Map 的 Map 获得了如下数据结构(3 层 map ): // data structure Map>>> tagTree
这可能是一种不好的做法,但我还没有找到更好的解决方案来解决我的问题。所以我有这张 map // Map>> private Map>> properties; 我想初始化它,这样我就不会得到 Null
我们在 JDK 1.7 中使用 HashMap,我在使用 SonarQube 进行代码审查时遇到了一些问题。 请考虑以下示例: public class SerializationTest imple
我是一名优秀的程序员,十分优秀!