我目前使用带有Loader的CursorAdapter. Loader加载的数据包含一个位置.我想从最近的到最远的地方订购我的物品.我已经计算了显示它的距离,我现在需要找到一种动态排序数据的方法.
我可能每次我的数据更改时都会修改CursorLoader排序,但是一次又一次地执行相同的SQL查询只是为了改变顺序看起来对我来说太过分了……
有没有办法动态排序CursorAdapter中的数据?
解决方法
您应该使用sortOrder –
CursorLoader’s构造函数的最后一个参数.
假设你的表有纬度为lat的列和经度为lon的列.用户的位置也通过纬度/经度userLat和userLon描述.对于排序我们不需要知道精确的距离 – 近似距离就足够了.为此你可以使用毕达哥拉斯定理.
sortOder将是这样的:abs(lat – userLat)* abs(lat – userLat)abs(lon-userLon)* abs(lon-userLon).此计算仅包含sqlite运算符支持.
注意1:您必须更改上面的代码才能提供正确的String,其中userLat和userLon将替换为其值.
注意2:您不能使用此公式来计算精确距离.