从MediaStore获取视频的添加/修改/拍摄日期

时间:2016-10-22 14:59:12

标签: android date video mediastore last-modified

我从哪里获取MediaStore视频的截取日期?我从MediaStore获得了以下字段。

MediaStore.Video.Media.DATE_MODIFIED
MediaStore.Video.Media.DATE_TAKEN
MediaStore.Video.Media.DATE_ADDED

返回的那些字段似乎是默认值 -

dateModified: 1477043336
dateTaken: 1477043336000
dateAdded: 1477043352

格式化日期 -

dateModified: 01/01/1970
dateTaken: 01/01/1970
dateAdded: 01/01/1970

我仔细检查了库存库>随机视频文件,我确实看到了正确的日期。我查看了MediaStore中的视频列,但我没有看到任何其他具有正确日期的列。

    SimpleDateFormat dateFormat = new SimpleDateFormat("MM/dd/yyyy");
    String formattedDate = dateFormat.format(new Date(row.getColumnIndex(MediaStore.Video.Media.DATE_MODIFIED)));

    String dateModified = dateFormat.format(new Date(row.getColumnIndex(MediaStore.Video.Media.DATE_MODIFIED)));
    String dateTaken = dateFormat.format(new Date(row.getColumnIndex(MediaStore.Video.Media.DATE_TAKEN) * 1000L));
    String dateAdded = dateFormat.format(new Date(row.getColumnIndex(MediaStore.Video.Media.DATE_ADDED) * 1000L));

    Log.d(TAG, "dateModified: "+dateModified);
    Log.d(TAG, "dateTaken: "+dateTaken);
    Log.d(TAG, "dateAdded: "+dateAdded);

    Log.d(TAG, "dateModified: "+row.getString(row.getColumnIndex(MediaStore.Video.Media.DATE_MODIFIED)));
    Log.d(TAG, "dateTaken: "+row.getString(row.getColumnIndex(MediaStore.Video.Media.DATE_TAKEN)));
    Log.d(TAG, "dateAdded: "+row.getString(row.getColumnIndex(MediaStore.Video.Media.DATE_ADDED)));

5 个答案:

答案 0 :(得分:1)

  

返回的那些字段似乎是默认值

我不知道为什么你的第二个最后有三个额外的零。但是,使用a Unix date converter site

  • dateModified = 1477043336 =星期五,2016年10月21日09:48:56 GMT
  • dateAdded = 1477043352 =星期五,2016年10月21日09:49:12 GMT

而{0}没有零的dateTakendateModified相同。因此,假设您可以找出零的来源(例如通过随机决定将值乘以1000L),您就拥有了有效的时间戳。

答案 1 :(得分:1)

在android中将epoch转换为正常日期的语法如下

long date=System.currentTimeMillis(); //current android time in epoch 

将纪元转换为“dd / MM / yyyy HH:mm:ss”dateformat 手段1477043336 = 21/10/2016 09:48:56

String NormalDate = new java.text.SimpleDateFormat("dd/MM/yyyy HH:mm:ss").format(new java.util.Date(date));

答案 2 :(得分:1)

查看界面上的注解DATE_ADDEDDATE_MODIFIED,从时代开始就注为SECONDS,而不是毫秒。 DATE_TAKEN被标注为距该纪元以来的毫秒数。

注释中的这种差异解释了CommonsWare的答案中零的差异。它还指导用法:

由于日期格式化程序通常期望以毫秒为单位的时间戳,因此您应将第二个值先乘以1000。

答案 3 :(得分:0)

这是获取日期格式实际结果的简单函数。

public String getDate(long val){
   val*=1000L;
   return new java.text.SimpleDateFormat("dd/MM/yyyy HH:mm:ss").format(new java.util.Date(val));
}

答案 4 :(得分:0)

//Just multiply it by 1000 to get correct date
     
    fun convertLongToDate(time: Long): String =
            if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.O) {
                DateTimeFormatter.ofPattern("dd MMMM yyyy").format(
                        Instant.ofEpochMilli(time*1000)
                                .atZone(ZoneId.systemDefault())
                                .toLocalDate())
            } else {
                SimpleDateFormat("dd MMMM yyyy").format(
                        Date(time * 1000)
                )
            }