RenameTo et delete() ne marchent pas
Armczbt
-
Armczbt -
Armczbt -
Bonjour,
aucune de mes procédures pour renommer le fichier et le supprimer ne marche...
le boolean supp = file.delete(); est toujours faux, je ne comprends pas pourquoi....
Voici ma procédure de suppression :
Merci
aucune de mes procédures pour renommer le fichier et le supprimer ne marche...
le boolean supp = file.delete(); est toujours faux, je ne comprends pas pourquoi....
Voici ma procédure de suppression :
private void deleteFile(int p, View view){ AlertDialog.Builder builder = new AlertDialog.Builder(context); builder.setTitle("Supprimer ?").setMessage(videoFolder.get(p).getTitle()).setNegativeButton("Annuler", (dialog, which) -> { }).setPositiveButton("Oui", (dialog, which) -> { Uri contentUri = ContentUris.withAppendedId(MediaStore.Video.Media.EXTERNAL_CONTENT_URI, Long.parseLong(videoFolder.get(p).getId())); File file = new File(videoFolder.get(p).getPath()); boolean deleted = file.delete(); if (deleted){ context.getApplicationContext().getContentResolver().delete(contentUri, null, null); videoFolder.remove(p); notifyItemRemoved(p); notifyItemRangeChanged(p,videoFolder.size()); Snackbar.make(view, "Fichier supprimé avec succès", Snackbar.LENGTH_SHORT).show(); }else{ Snackbar.make(view, "Erreur, le fichier n'a pas été supprimé", Snackbar.LENGTH_SHORT).show(); } }).show(); }
Merci
Configuration: Windows / Chrome 92.0.4515.107
A voir également:
- RenameTo et delete() ne marchent pas
- Hiberfil.sys delete - Guide
- Juste delete me - Guide
- *#9900# delete dumpstate/logcat ✓ - Forum Samsung
- Delete doctor - Télécharger - Divers Utilitaires
- Delete dumpstate/logcat en francais - Forum Samsung
7 réponses
Hello, j'ai pris connaissance des nouvelles perms que nécessite android 11... Mon code marche très bien sur Android 10 et - mais il y a une nouvelle approche sur android 11.
il faut utiliser un pendingintent createDeleteRequest(https://developer.android.com/reference/android/provider/MediaStore#createDeleteRequest(android.content.ContentResolver,%20java.util.Collection%3Candroid.net.Uri%3E
Seulement, je ne sais pas comment récupérer le OnActivityResult pour supprimer mon fichier correctement en fonction du résultat.
Voilà mon code:
Merci !
il faut utiliser un pendingintent createDeleteRequest(https://developer.android.com/reference/android/provider/MediaStore#createDeleteRequest(android.content.ContentResolver,%20java.util.Collection%3Candroid.net.Uri%3E
Seulement, je ne sais pas comment récupérer le OnActivityResult pour supprimer mon fichier correctement en fonction du résultat.
Voilà mon code:
private void deleteFile(int p, View view){ AlertDialog.Builder builder = new AlertDialog.Builder(context); builder.setTitle("Supprimer ?").setMessage(videoFolder.get(p).getTitle()).setNegativeButton("Annuler", (dialog, which) -> { }).setPositiveButton("Oui", (dialog, which) -> { ArrayList<Uri> fichiers = new ArrayList<>(); Uri contentUri = ContentUris.withAppendedId(MediaStore.Video.Media.EXTERNAL_CONTENT_URI, Long.parseLong(videoFolder.get(p).getId())); File file = new File(videoFolder.get(p).getPath()); fichiers.add(contentUri); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) { PendingIntent demande = MediaStore.createDeleteRequest(context.getContentResolver(), fichiers); try { ((Activity) context).startIntentSenderForResult(demande.getIntentSender(),1,new Intent(), 0,0,0); } catch (IntentSender.SendIntentException e) { e.printStackTrace(); } } boolean deleted = file.delete(); if (deleted){ context.getApplicationContext().getContentResolver().delete(contentUri, null, null); videoFolder.remove(p); notifyItemRemoved(p); notifyItemRangeChanged(p,videoFolder.size()); Snackbar.make(view, "Fichier supprimé avec succès", Snackbar.LENGTH_SHORT).show(); }else{ Snackbar.make(view, "Erreur, le fichier n'a pas été supprimé", Snackbar.LENGTH_SHORT).show(); } }).show(); }
Merci !
Quelque chose dans ce goût là:
Le switch peut être remplacé par un simple
@Override public void onActivityResult(final int requestCode, final int resultCode, final Intent data) { Log.d(this, "onActivityResult " + requestCode + " " + resultCode + " " + data); switch (requestCode) { case xxx: // je ne sais pas quel requestCOde cela peut être. A tester if (resultCode == Activity.RESULT_OK) { // ici retour avec succès de la requête de suppression } break; } super.onActivityResult(requestCode, resultCode, data); }
Le switch peut être remplacé par un simple
ifsi tu n'as pas de multiple combinaisons
oui je vois merci,
le problème c'est que je ne sais pas dans quel .java l'implémenter parce que je veux donc mettre mon code pour supprimer le fichier dans le OnActivityResult, sauf que dans mes activity je n'ai pas la variable qui correspond aux fichiers...
le problème c'est que je ne sais pas dans quel .java l'implémenter parce que je veux donc mettre mon code pour supprimer le fichier dans le OnActivityResult, sauf que dans mes activity je n'ai pas la variable qui correspond aux fichiers...
Elle est où ta variable ? Dans un Fragment ? Tu as la même callback:
https://developer.android.com/reference/android/app/Fragment#onActivityResult(int,%20int,%20android.content.Intent)
https://developer.android.com/reference/android/app/Fragment#onActivityResult(int,%20int,%20android.content.Intent)
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Je vous mets l'organisation de mon code ainsi que tous les codes.
Ici, tout se passe dans videosadpater. Seulement, je suis obligé de mettre le OnActivityResult sur une activity mais je n'aurai pas le chemin de mon fichier.

MainActivity.java : https://textup.fr/570343Lh
VideoFolder.java : https://textup.fr/570345zd
VideoPlayer.java : https://textup.fr/570347Np
FolderAdapter : https://textup.fr/570348bE
VideosAdapter : https://textup.fr/570349F0
SplashScreen : https://textup.fr/570350AG
VideoModel : https://textup.fr/570351Ze
Ici, tout se passe dans videosadpater. Seulement, je suis obligé de mettre le OnActivityResult sur une activity mais je n'aurai pas le chemin de mon fichier.

MainActivity.java : https://textup.fr/570343Lh
VideoFolder.java : https://textup.fr/570345zd
VideoPlayer.java : https://textup.fr/570347Np
FolderAdapter : https://textup.fr/570348bE
VideosAdapter : https://textup.fr/570349F0
SplashScreen : https://textup.fr/570350AG
VideoModel : https://textup.fr/570351Ze
Voici un tuto pour les interfaces : https://www.geeksforgeeks.org/how-to-create-interfaces-in-android-studio/
Pour le Broadcast, c'est ici : https://www.vogella.com/tutorials/AndroidBroadcastReceiver/article.html avec la doc officielle
Pour le Broadcast, c'est ici : https://www.vogella.com/tutorials/AndroidBroadcastReceiver/article.html avec la doc officielle
Merci pour le lien des tutos, j'ai rajouté :
à ma mainactivity, et maintenant j'aimerai implémenter OnActivityResult and l'adapter mais je ne sais comment faire...
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
}
à ma mainactivity, et maintenant j'aimerai implémenter OnActivityResult and l'adapter mais je ne sais comment faire...
PendingIntent demande = MediaStore.createDeleteRequest(context.getContentResolver(), fichiers); try { ((Activity) context).startIntentSenderForResult(demande.getIntentSender(),1,new Intent(), 0,0,0); } catch (IntentSender.SendIntentException e) { e.printStackTrace(); }
Le code ci-dessus, aujourd'hui dans ton adapter, doit être placé dans ton Activity: c'est elle qui doit lancer l'Intent pour pouvoir récupérer le résultat
Tu as le choix de faire ça "proprement" avec une interface par exemple.
Tu définis une interface de ce type:
Ensuite, tu implémentes cette interface dans ton Activity
Et dans ton Adapter, quelque chose comme ça:
Quelques remarques :
- je n'ai pas testé, j'ai juste codé dans le forum. Théroriquement, ça doit fonctionner mais je ne suis pas à l'abri d'une erreur de syntaxe
- il est bon de respecter des conventions de nommage : tous tes composants dérivant d'Activity doivent l'illustré dans le nom. Par exemple,
Tu définis une interface de ce type:
interface DeleteFileInterface { public void deleteFile(Uri fileUri); }
Ensuite, tu implémentes cette interface dans ton Activity
public class VideoFolder extends AppCompatActivity implements SearchView.OnQueryTextListener, DeleteFileInterface { public void loadVideos(){ videoModelArrayList = getallVideoFromFolder(this, name); if (name!=null && videoModelArrayList.size()>0){ videosAdapter = new VideosAdapter(videoModelArrayList, this, this); // CHANGEMENT ICI recyclerView.setAdapter(videosAdapter); recyclerView.setLayoutManager(new LinearLayoutManager(this, RecyclerView.VERTICAL, false)); }else { Toast.makeText(this, "Aucun fichier trouvé", Toast.LENGTH_SHORT).show();; } } @Override public void deleteFile(Uri fileUri) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) { ArrayList<Uri> fichiers = new ArrayList<>(); fichiers.add(fileUri); PendingIntent demande = MediaStore.createDeleteRequest(context.getContentResolver(), fichiers); try { ((Activity) context).startIntentSenderForResult(demande.getIntentSender(), 1, new Intent(), 0, 0, 0); } catch (IntentSender.SendIntentException e) { e.printStackTrace(); } } }
Et dans ton Adapter, quelque chose comme ça:
public class VideosAdapter extends RecyclerView.Adapter<VideosAdapter.MyHolder> { public static ArrayList<VideoModel> videoFolder = new ArrayList<>(); private final Context context; private DeleteFileInterface listener; public VideosAdapter(ArrayList<VideoModel> videoFolder, Context context, DeleteFileInterface listener) { VideosAdapter.videoFolder = videoFolder; this.context = context; this.listener = listener; } private void deleteFile(int p, View view){ AlertDialog.Builder builder = new AlertDialog.Builder(context); builder.setTitle("Supprimer ?").setMessage(videoFolder.get(p).getTitle()).setNegativeButton("Annuler", (dialog, which) -> { }).setPositiveButton("Oui", (dialog, which) -> { ArrayList<Uri> fichiers = new ArrayList<>(); Uri contentUri = ContentUris.withAppendedId(MediaStore.Video.Media.EXTERNAL_CONTENT_URI, Long.parseLong(videoFolder.get(p).getId())); File file = new File(videoFolder.get(p).getPath()); fichiers.add(contentUri); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) { if (listenet != null) { listener.deleteFile(contentUri); } }else{ boolean deleted = file.delete(); if (deleted){ context.getApplicationContext().getContentResolver().delete(contentUri, null, null); videoFolder.remove(p); notifyItemRemoved(p); notifyItemRangeChanged(p,videoFolder.size()); Snackbar.make(view, "Fichier supprimé avec succès", Snackbar.LENGTH_SHORT).show(); }else{ Snackbar.make(view, "Erreur, le fichier n'a pas été supprimé", Snackbar.LENGTH_SHORT).show(); } } }).show(); }
Quelques remarques :
- je n'ai pas testé, j'ai juste codé dans le forum. Théroriquement, ça doit fonctionner mais je ne suis pas à l'abri d'une erreur de syntaxe
- il est bon de respecter des conventions de nommage : tous tes composants dérivant d'Activity doivent l'illustré dans le nom. Par exemple,
VideoFolderdevient
VideoFolderActivity.