NullPointerException в метаданных-экстракторе

Я использую библиотеку метаданных-экстракторов, чтобы читать exif-данные с фотографий в телефоне. https://github.com/drewnoakes/metadata-extractor

Я хочу получить GPS и некоторые конкретные теги из метаданных, например: широта и долгота, фокусное расстояние. Я пишу код, как показано ниже:

...
Metadata metadata = ImageMetadataReader.readMetadata(file);
String metaDataString = "" ;
GpsDirectory gpsDirectory = metadata.getFirstDirectoryOfType(GpsDirectory.class);    
metaDataString += "Long: " + String.valueOf(gpsDirectory.getGeoLocation().getLongitude()) + "Lat: " + String.valueOf(gpsDirectory.getGeoLocation().getLatitude());

ExifSubIFDDirectory exifSubIFDDirectory = metadata.getFirstDirectoryOfType(ExifSubIFDDirectory.class);
metaDataString += "[focal length]" + exifSubIFDDirectory.getString(ExifSubIFDDirectory.TAG_FOCAL_LENGTH);

...

Я получил NullException с кодом выше. Пожалуйста, помогите мне разобраться. Заранее спасибо.

** Добавить журнал **

java.lang.RuntimeException: An error occured while executing doInBackground()
       at android.os.AsyncTask$3.done(AsyncTask.java:299)
       at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
       at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
       at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
       at java.util.concurrent.FutureTask.run(FutureTask.java:137)
       at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
       at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
       at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
       at java.lang.Thread.run(Thread.java:856)
Caused by: java.lang.NullPointerException
       at com.testing.MetaData.LoadPhoto.doInBackground(LoadPhoto.java:113)
       at android.os.AsyncTask$2.call(AsyncTask.java:287)
       at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
       at java.util.concurrent.FutureTask.run(FutureTask.java:137)
       at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
       at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
       at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
       at java.lang.Thread.run(Thread.java:856)

Ошибка NPE в кодовой строке 113:

metaDataString += "Long: " + String.valueOf(gpsDirectory.getGeoLocation().getLongitude()) + "Lat: " + String.valueOf(gpsDirectory.getGeoLocation().getLatitude());

2 ответа

Решение

Привет ребята, вы все в порядке. После отладки я увидел, что некоторые из моих фотографий не имеют GPS, и ноль. Я публикую код для управления нулевым значением, как показано ниже (это также может быть применено для другого конкретного тега)

// Check if metadata contains the specific Directory
if (metadata.containsDirectoryOfType(GpsDirectory.class)) {

      GpsDirectory gpsDirectory = metadata.getFirstDirectoryOfType(GpsDirectory.class);

      //Check if Directory contains the specific Tag
      if(gpsDirectory.containsTag(GpsDirectory.TAG_LATITUDE)&& gpsDirectory.containsTag(GpsDirectory.TAG_LONGITUDE)) {

          metaDataString = "[Longtitude]: " + String.valueOf(gpsDirectory.getGeoLocation().getLongitude()) + ", " +
                                    "[Latitude]: " + String.valueOf(gpsDirectory.getGeoLocation().getLatitude()) + ", ";
      }
      else {
        //Show error or notification
      }
}

Вот и все, какие-либо проблемы или лучше реализовать, пожалуйста, оставьте комментарий.

Если ваше изображение не содержит данных GPS, возвращенный каталог будет нулевым. Обязательно используйте нулевую проверку. Проверьте снова с изображением, которое определенно содержит данные GPS.

Другие вопросы по тегам