我目前使用带有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:您不能使用此公式来计算精确距离.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。