[Android] Data binding for album view

Geoffrey Métais git at videolan.org
Thu Sep 3 17:45:45 CEST 2015


vlc-ports/android | branch: data-binding | Geoffrey Métais <geoffrey.metais at gmail.com> | Thu Sep  3 17:45:12 2015 +0200| [b30903d45fb29e88498e1697e1985657e1407b97] | committer: Geoffrey Métais

Data binding for album view

> http://git.videolan.org/gitweb.cgi/vlc-ports/android.git/?a=commit;h=b30903d45fb29e88498e1697e1985657e1407b97
---

 vlc-android/res/layout/audio_browser_item.xml      |   10 ++--
 .../org/videolan/vlc/gui/audio/AlbumAdapter.java   |   53 +++++++++-----------
 2 files changed, 31 insertions(+), 32 deletions(-)

diff --git a/vlc-android/res/layout/audio_browser_item.xml b/vlc-android/res/layout/audio_browser_item.xml
index 79d3f65..1ce816a 100644
--- a/vlc-android/res/layout/audio_browser_item.xml
+++ b/vlc-android/res/layout/audio_browser_item.xml
@@ -2,10 +2,14 @@
 <layout xmlns:android="http://schemas.android.com/apk/res/android">
     <data>
         <import type="android.view.View"/>
+        <import type="android.text.TextUtils"/>
         <variable
             name="item"
             type="org.videolan.vlc.gui.audio.AudioBrowserListAdapter.ListItem"/>
         <variable
+            name="media"
+            type="org.videolan.vlc.MediaWrapper"/>
+        <variable
             name="cover"
             type="android.graphics.drawable.BitmapDrawable"/>
         <variable
@@ -54,7 +58,7 @@
                     android:singleLine="true"
                     android:ellipsize="middle"
                     android:maxLines="1"
-                    android:text="@{item.mTitle}"
+                    android:text="@{media.title ?? item.mTitle}"
                     android:fontFamily="sans-serif-light"
                     android:textColor="?attr/list_title"
                     android:textSize="16sp" />
@@ -66,8 +70,8 @@
                     android:singleLine="true"
                     android:ellipsize="middle"
                     android:maxLines="1"
-                    android:text="@{item.mSubTitle}"
-                    android:visibility="@{item.mSubTitle != null ? View.VISIBLE : View.GONE}"
+                    android:text="@{media.artist ?? item.mSubTitle}"
+                    android:visibility="@{TextUtils.isEmpty(item.mSubTitle) && TextUtils.isEmpty(media.artist)  ? View.GONE : View.VISIBLE}"
                     android:fontFamily="sans-serif-light"
                     android:textColor="?attr/list_subtitle" />
             </LinearLayout>
diff --git a/vlc-android/src/org/videolan/vlc/gui/audio/AlbumAdapter.java b/vlc-android/src/org/videolan/vlc/gui/audio/AlbumAdapter.java
index 0c3d871..939a9a1 100644
--- a/vlc-android/src/org/videolan/vlc/gui/audio/AlbumAdapter.java
+++ b/vlc-android/src/org/videolan/vlc/gui/audio/AlbumAdapter.java
@@ -25,20 +25,22 @@ package org.videolan.vlc.gui.audio;
 
 import android.content.Context;
 import android.database.DataSetObserver;
+import android.databinding.DataBindingUtil;
 import android.support.annotation.Nullable;
 import android.view.LayoutInflater;
 import android.view.View;
 import android.view.ViewGroup;
 import android.widget.ArrayAdapter;
-import android.widget.ImageView;
-import android.widget.TextView;
+import android.widget.LinearLayout;
 
 import org.videolan.vlc.MediaWrapper;
 import org.videolan.vlc.R;
+import org.videolan.vlc.databinding.AudioBrowserItemBinding;
+import org.videolan.vlc.interfaces.IAudioClickHandler;
 
 import java.util.ArrayList;
 
-public class AlbumAdapter extends ArrayAdapter<MediaWrapper> {
+public class AlbumAdapter extends ArrayAdapter<MediaWrapper> implements IAudioClickHandler{
 
     private ArrayList<MediaWrapper> mMediaList;
 
@@ -56,31 +58,20 @@ public class AlbumAdapter extends ArrayAdapter<MediaWrapper> {
         MediaWrapper mw = mMediaList.get(position);
         if (v == null) {
             LayoutInflater inflater = (LayoutInflater) getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
-            v = inflater.inflate(R.layout.audio_browser_item, parent, false);
             holder = new ViewHolder();
-            holder.title = (TextView) v.findViewById(R.id.title);
-            holder.subtitle = (TextView) v.findViewById(R.id.subtitle);
-            holder.more = (ImageView) v.findViewById(R.id.item_more);
-            holder.footer = v.findViewById(R.id.footer);
+            holder.binding = DataBindingUtil.inflate(inflater, R.layout.audio_browser_item, parent, false);
+            v = holder.binding.getRoot();
 
-            v.setTag(holder);
+            v.setTag(R.layout.audio_browser_item, holder);
         } else
-            holder = (ViewHolder) v.getTag();
-
-        holder.title.setText(mw.getTitle());
-        holder.subtitle.setText(mw.getArtist());
-        holder.footer.setVisibility(position == mMediaList.size() - 1 ? View.INVISIBLE : View.VISIBLE);
-        if (mContextPopupMenuListener != null)
-            holder.more.setOnClickListener(new View.OnClickListener() {
-                @Override
-                public void onClick(View v) {
-                    if (mContextPopupMenuListener != null)
-                        mContextPopupMenuListener.onPopupMenu(v, position);
-                }
-            });
-        else
-            holder.more.setVisibility(View.GONE);
-        v.findViewById(R.id.cover).setVisibility(View.GONE);
+            holder = (ViewHolder) v.getTag(R.layout.audio_browser_item);
+
+        holder.position = position;
+        holder.binding.setMedia(mw);
+        holder.binding.setFooter(position != mMediaList.size() - 1);
+        holder.binding.setClickable(mContextPopupMenuListener != null);
+        holder.binding.setHandler(this);
+        holder.binding.executePendingBindings();
         return v;
     }
 
@@ -108,11 +99,15 @@ public class AlbumAdapter extends ArrayAdapter<MediaWrapper> {
             super.unregisterDataSetObserver(observer);
     }
 
+    @Override
+    public void onMoreClick(View v) {
+        if (mContextPopupMenuListener != null)
+                mContextPopupMenuListener.onPopupMenu(v, ((ViewHolder) ((LinearLayout)v.getParent().getParent()).getTag(R.layout.audio_browser_item)).position);
+    }
+
     static class ViewHolder {
-        TextView title;
-        TextView subtitle;
-        ImageView more;
-        View footer;
+        AudioBrowserItemBinding binding;
+        int position;
     }
 
     public interface ContextPopupMenuListener {



More information about the Android mailing list