Hello,
This library lists the media content (audio, image and video) of the MediaStore (a database containing meta data for all available media on both internal and external storage devices). It includes an audio player and a media scanner (to scan the new media and add them to the MediaStore).
I added new functions to the library esAudioMediaBrowser provided by Lagore, improved a bit the existing ones, and extended the stuff to images and videos.
The demo (a media gallery) needs the libs Reflection & StringUtils. It displays only files stored on your external SD card (but the lib can handle internal files).
This lib does not work with Android versions < Gingerbread (2.3).
List of properties and methods:
There's a known bug on some Android versions with micro thumbnails:
If the micro thumbnail can't be generated (e.g. video file format not recognized), the result is either null or a random thumbnail. Thus, for video files, it is strongly recommended to check if the mini thumbnail is initialized before trying to get the micro thumbnail.
v1.2:
I fixed two bugs.
v1.21:
I removed the excessive log entries.
I removed all the Try/Catch that silently trapped errors.
v1.3:
This version requires Java 7 and B4A v3.82+.
I added 3 functions:
- GetImageFileInfoByID(External As Boolean, ID As Long) As Map;
- GetVideoFileInfoByID(External As Boolean, ID As Long) As Map;
- ScanNewMedia(Paths() As String).
I updated the demo so it works with recent Android versions.
v1.31:
I fixed a mistake in two functions introduced in v1.3.
v1.4:
I fixed an issue with API 30;
I added five functions: GetAudioFieldByID, GetImageFieldByID, GetVideoFieldByID, GetExifAttribute and GetExifLatLong;
I added a few FIELD constants;
I updated the demo to display the following fields: composer, orientation, latitude and longitude.
Enjoy,
Fred
			
			This library lists the media content (audio, image and video) of the MediaStore (a database containing meta data for all available media on both internal and external storage devices). It includes an audio player and a media scanner (to scan the new media and add them to the MediaStore).
I added new functions to the library esAudioMediaBrowser provided by Lagore, improved a bit the existing ones, and extended the stuff to images and videos.
The demo (a media gallery) needs the libs Reflection & StringUtils. It displays only files stored on your external SD card (but the lib can handle internal files).
This lib does not work with Android versions < Gingerbread (2.3).
List of properties and methods:
- GetAudioFieldByID (External As Boolean, ID As Long, Field As String) As String
 Returns a field from the MediaStore about the specified audio file.
 Examples of field: FIELD_COMPOSER, FIELD_DATE_MODIFIED, FIELD_MIME_TYPE, FIELD_SIZE...
- GetAudioFileInfo (Path As String, File As String) As Map
 Returns a Map containing info from the MediaStore about an audio file.
 The fields that are returned are:
 "ID"
 "Title"
 "Album"
 "Artist"
 "Track"
 "Year"
 "Location"
 "DisplayName"
 "Duration" (in ms)
- GetAudioFileInfoByID (External As Boolean, ID As Long) As Map
 Returns a Map containing info from the MediaStore about an audio file.
 The fields that are returned are:
 "ID"
 "Title"
 "Album"
 "Artist"
 "Track"
 "Year"
 "Location"
 "DisplayName"
 "Duration" (in ms)
- GetExifAttribute (Location As String, Attribute As String) As String
 Returns the requested attribute from the Exif data of the specified image.
 Location = complete path name for the file.
 The complete list of attributes can be found here: https://developer.android.com/reference/android/media/ExifInterface
- GetExifLatLong (Location As String, LatLong As Float()) As Boolean
 Stores the latitude and longitude value of the specified image in a float array. Returns False if these Exif data are not available.
 Location = complete path name for the file.
- GetExtImageFileInfo (Location As String) As Map
 Returns a Map containing info from the MediaStore about an external image file.
 Location = complete path name for the file.
 The fields that are returned are:
 "ID"
 "Location"
 "DisplayName"
 "DateTaken" (in ticks from 1970)
 "Height" (with Android 3.0+)
 "Width" (with Android 3.0+)
 "Size" (in bytes)
- GetExtVideoFileInfo (Location As String) As Map
 Returns a Map containing info from the MediaStore about an external video file.
 Location = complete path name for the file.
 The fields that are returned are:
 "ID"
 "Location"
 "DisplayName"
 "DateTaken" (in ticks from 1970)
 "Resolution" (can be Null for some files)
 "Size" (in bytes)
- GetImageDimensions (Location As String) As Map
 Returns a map containing width and height of the specified file.
 Location = complete path name for the file.
- GetImageFieldByID (External As Boolean, ID As Long, Field As String) As String
 Returns a field from the MediaStore about the specified image file.
 Examples of field: FIELD_DATE_MODIFIED, FIELD_MIME_TYPE, FIELD_ORIENTATION...
- GetImageFileInfoByID (External As Boolean, ID As Long) As Map
 Returns a Map containing info from the MediaStore about an image file.
 The fields that are returned are:
 "ID"
 "Location"
 "DisplayName"
 "DateTaken" (in ticks from 1970)
 "Height" (with Android 3.0+)
 "Width" (with Android 3.0+)
 "Size" (in bytes)
- GetImgThumbnailByID (ID As Long, Mini As Boolean) As android.graphics.Bitmap
 Returns the micro thumbnail (96x96) or mini thumbnail (512x384) of an image file (it is generated if it doesn't exist).
- GetMediaAudioList (External As Boolean, SortCol As String) As Map
 Returns a Map containing a list of all Audio files in the MediaStore which can be sorted.
 The allowed fields for sorting are:
 Null (= FIELD_ID)
 FIELD_ALBUM
 FIELD_ARTIST
 FIELD_COMPOSER
 FIELD_DATA (location)
 FIELD_DATE_ADDED
 FIELD_DATE_MODIFIED
 FIELD_DISPLAY_NAME
 FIELD_DURATION
 FIELD_MIME_TYPE
 FIELD_SIZE
 FIELD_TITLE
 FIELD_TRACK
 FIELD_YEAR
 The fields that are returned are:
 "ID"
 "Title"
 "Album"
 "Artist"
 "Track"
 "Year"
 "Location"
 "DisplayName"
 "Duration" (in ms)
- GetMediaImageList (External As Boolean, SortCol As String) As Map
 Returns a Map containing a list of all Image files in the MediaStore which can be sorted.
 The allowed fields for sorting are:
 Null (= FIELD_ID)
 FIELD_DATA (location)
 FIELD_DATE_ADDED
 FIELD_DATE_MODIFIED
 FIELD_DATE_TAKEN
 FIELD_DISPLAY_NAME
 FIELD_HEIGHT
 FIELD_MIME_TYPE
 FIELD_ORIENTATION
 FIELD_SIZE
 FIELD_TITLE
 FIELD_WIDTH
 The fields that are returned are:
 "ID"
 "Location"
 "DisplayName"
 "DateTaken" (in ticks from 1970)
 "Height" (with Android 3.0+)
 "Width" (with Android 3.0+)
 "Size" (in bytes)
- GetMediaVideoList (External As Boolean, SortCol As String) As Map
 Returns a Map containing a list of all Video files in the MediaStore which can be sorted.
 The allowed fields for sorting are:
 Null (= FIELD_ID)
 FIELD_DATA (location)
 FIELD_DATE_ADDED
 FIELD_DATE_MODIFIED
 FIELD_DATE_TAKEN
 FIELD_DISPLAY_NAME
 FIELD_MIME_TYPE
 FIELD_RESOLUTION
 FIELD_SIZE
 FIELD_TITLE
 The fields that are returned are:
 "ID"
 "Location"
 "DisplayName"
 "DateTaken" (in ticks from 1970)
 "Resolution" (can be Null for some files)
 "Size" (in bytes)
- GetVideoFieldByID (External As Boolean, ID As Long, Field As String) As String
 Returns a field from the MediaStore about the specified video file.
 Examples of field: FIELD_DATE_ADDED, FIELD_DATE_MODIFIED, FIELD_MIME_TYPE...
- GetVideoFileInfoByID (External As Boolean, ID As Long) As Map
 Returns a Map containing info from the MediaStore about a video file.
 The fields that are returned are:
 "ID"
 "Location"
 "DisplayName"
 "DateTaken" (in ticks from 1970)
 "Resolution" (can be Null for some files)
 "Size" (in bytes)
- GetVideoThumbnailByID (ID As Long, Mini As Boolean) As android.graphics.Bitmap
 Returns the micro thumbnail (96x96) or mini thumbnail (512x384) of a video file (it is generated if it doesn't exist).
 There's a known bug on some Android versions with micro thumbnails:
 If the micro thumbnail can't be generated (e.g. video file format not recognized), the result is either null or a random thumbnail. Thus, for video files, it is strongly recommended to check if the mini thumbnail is initialized before trying to get the micro thumbnail.
- Initialize (EventName As String)
- MediaAudioPlay (External As Boolean, ID As Int)
 Plays an audio file.
 Raises the "MediaCompleted" event when the file end is reached.
- MediaIsLooping As Boolean
 Checks whether the player is looping or non-looping.
- MediaIsPlaying As Boolean
- MediaLength As Int
 Returns the duration in ms.
- MediaPause
- MediaPosition As Int
 Gets the current playback position.
- MediaResume
- MediaSeek (position As Int)
 Seeks to specified time position (in ms).
 Raises the event "SeekCompleted" when the position change has been completed.
- MediaSetLooping (Looping As Boolean)
 Sets the player to be looping or non-looping.
- MediaSetVolume (leftVolume As Float, rightVolume As Float)
 Sets the volume on this player (and this player only).
 Note that the passed volume values are raw scalars. UI controls should be scaled logarithmically.
 This function must be called AFTER MediaAudioPlay.
- MediaStop
 Stops the playback and releases the allocated resources.
- ScanNewMedia (Paths As String())
 Requests the media scanner to scan the given files and add them to the MediaStore.
 Raises the "ScanCompleted" event after each file is scanned.
There's a known bug on some Android versions with micro thumbnails:
If the micro thumbnail can't be generated (e.g. video file format not recognized), the result is either null or a random thumbnail. Thus, for video files, it is strongly recommended to check if the mini thumbnail is initialized before trying to get the micro thumbnail.
v1.2:
I fixed two bugs.
v1.21:
I removed the excessive log entries.
I removed all the Try/Catch that silently trapped errors.
v1.3:
This version requires Java 7 and B4A v3.82+.
I added 3 functions:
- GetImageFileInfoByID(External As Boolean, ID As Long) As Map;
- GetVideoFileInfoByID(External As Boolean, ID As Long) As Map;
- ScanNewMedia(Paths() As String).
I updated the demo so it works with recent Android versions.
v1.31:
I fixed a mistake in two functions introduced in v1.3.
v1.4:
I fixed an issue with API 30;
I added five functions: GetAudioFieldByID, GetImageFieldByID, GetVideoFieldByID, GetExifAttribute and GetExifLatLong;
I added a few FIELD constants;
I updated the demo to display the following fields: composer, orientation, latitude and longitude.
Enjoy,
Fred
Attachments
			
				Last edited: 
			
		
	
							 
				 
 
		 
 
		 
 
		 
 
		 
 
		 
 
		 
 
		 
 
		 
 
		 
 
		 
 
		 
 
		