关于List的排序(文件按时间排序)

一般排序是在后台做好了的,但是
有一个需求:要求多选图片、视频,于是写了一个检索照片的Activity并显示,且把最近的照片放在上面,也就是按时间降序排列。
当时做的时候,本打算直接获取图片信息,但是又因为有视频,所以干脆直接用list做排序
第一个方法:
首先我们建一个文件bean类:filesData:

public class FilesData implements Serializable {
    /**
     * 文件take日期
     */
    private String fileDate;

    /**
     * 文件日期:排序用
     */
    private Long sortdate;

    /**
     * 是否需要排序:1:需要;0:不需要
     */
    private String isSort;

    public String getIsSort() {
        return isSort;
    }
    public void setIsSort(String isSort) {
        this.isSort = isSort;
    }
    public String getFileDate() {
        return fileDate;
    }

    public void setFileDate(String fileDate) {
        this.fileDate = fileDate;
    }

    public Long getSortdate() {
        return sortdate;
    }

    public void setSortdate(Long sortdate) {
        this.sortdate = sortdate;
    }

}

然后获取到文件的时间:
这里我们按照时间排序的话,我bean里有一个时间的Long值,根据这个来排序

ContentResolver mContentResolver = SampleCameraActivity.this.getContentResolver();
Uri mImageUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;//从外置内存卡获取图片uri
                    mCursor = mContentResolver.query(
                            mImageUri,
                            null,
                            MediaStore.Images.Media.MIME_TYPE + "=? or " + MediaStore.Images.Media.MIME_TYPE + "=?",
                            new String[]{"image/jpeg", "image/png"},
                            null);
 while (mCursor.moveToNext()) {
                        // 获取图片的路径
                        String path = mCursor.getString(mCursor
                                .getColumnIndex(MediaStore.Images.Media.DATA));
                        //获取图片的创建日期
                        Long dateLong=mCursor.getLong(mCursor  .getColumnIndex(MediaStore.Images.Media.DATE_TAKEN));
Date date = new Date(dateLong); // 根据long类型的毫秒数生命一个date类型的时间
                        String dateStr= DateUtil.date2str(date,DateUtil.Date_Pattern_Short1);
FilesData filesData=new FilesData();
filesData.setFileDate(dateStr);
filesData.setSortdate(dateLong);
filesData.setIsSort("1");//需要排序
filesDataList.add(filesData);
}

然后我们就可以在我们需要排序显示的地方(比如adapter里)排序显示了,:
这里才是排序,前面都是数据

 if ("1".equals(filesDataList.get(0).getIsSort())) {//判断是否有排序的需求
            Collections.sort(this.filesDataList, new Comparator<FilesData>() {
                @Override
                public int compare(FilesData o1, FilesData o2) {
                    int i = (int) (o1.getSortdate() - o2.getSortdate());//升序
                    //int i = (int) (o2.getSortdate() - o1.getSortdate());//降序
                    return i;
                }
            });
        }

第二个方法:
用需要排序的bean去实现Comparable接口:

public class FilesData implements Comparable<FilesData> {
...
//用需要排序的字段进行排序
 @Override
    public int compareTo(@NonNull FilesData o) {
//        return this.getSortdate.compareTo(o.getSortdate);//升序
    return o.getSortdate.compareTo(this.getSortdate);//降序
    }
}

然后同样,在我们需要排序显示的地方直接调用排序就好:

Collections.sort(filesDataList);

两个方式都很简单!

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值