org.videolan.vlc2.gui.SidebarAdapter.java Source code

Java tutorial

Introduction

Here is the source code for org.videolan.vlc2.gui.SidebarAdapter.java

Source

/*****************************************************************************
 * SidebarAdapter.java
 *****************************************************************************
 * Copyright  2012-2013 VLC authors and VideoLAN
 * Copyright  2012-2013 Edward Wang
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
 *****************************************************************************/
package org.videolan.vlc2.gui;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;

import org.videolan.vlc2.R;
import org.videolan.vlc2.VLCApplication;
import org.videolan.vlc2.gui.audio.AudioBrowserFragment;
import org.videolan.vlc2.gui.video.VideoGridFragment;
import org.videolan.vlc2.util.Util;

import android.content.Context;
import android.graphics.Typeface;
import android.graphics.drawable.Drawable;
import android.support.v4.app.Fragment;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

public class SidebarAdapter extends BaseAdapter {
    public final static String TAG = "VLC/SidebarAdapter";

    static class SidebarEntry {
        String id;
        String name;
        int attributeID;

        public SidebarEntry(String _id, int _name, int _attributeID) {
            this.id = _id;
            this.name = VLCApplication.getAppContext().getString(_name);
            this.attributeID = _attributeID;
        }
    }

    private Context mContext;
    private LayoutInflater mInflater;
    static final List<SidebarEntry> entries;
    public static final List<String> sidebarFragments;
    private HashMap<String, Fragment> mFragments;
    private String mCurrentFragmentId;

    static {
        SidebarEntry entries2[] = { new SidebarEntry("video", R.string.video, R.attr.ic_menu_video),
                new SidebarEntry("audio", R.string.audio, R.attr.ic_menu_audio),
                new SidebarEntry("directories", R.string.directories, R.attr.ic_menu_folder),
                new SidebarEntry("history", R.string.history, R.attr.ic_menu_history),
                //new SidebarEntry( "bookmarks", R.string.bookmarks, R.drawable.ic_bookmarks ),
                //new SidebarEntry( "playlists", R.string.playlists, R.drawable.icon ),
        };
        entries = Arrays.asList(entries2);

        sidebarFragments = new ArrayList<String>();
        for (SidebarEntry e : entries2) {
            sidebarFragments.add(e.id);
        }
    }

    public SidebarAdapter(Context context) {
        mContext = context;
        mInflater = LayoutInflater.from(context);
        mFragments = new HashMap<String, Fragment>(entries.size());
    }

    @Override
    public int getCount() {
        return entries.size();
    }

    @Override
    public Object getItem(int position) {
        return entries.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position; // The SidebarEntry list is unique
    }

    @Override
    public View getView(int position, View v, ViewGroup parent) {
        SidebarEntry sidebarEntry = entries.get(position);

        /* If view not created */
        if (v == null) {
            v = mInflater.inflate(R.layout.sidebar_item, parent, false);
        }
        TextView textView = (TextView) v;
        textView.setText(sidebarEntry.name);
        Drawable img = VLCApplication.getAppResources()
                .getDrawable(Util.getResourceFromAttribute(mContext, sidebarEntry.attributeID));
        if (img != null) {
            int dp_32 = Util.convertDpToPx(32);
            img.setBounds(0, 0, dp_32, dp_32);
            textView.setCompoundDrawables(img, null, null, null);
        }
        // Set in bold the current item.
        if (mCurrentFragmentId.equals(sidebarEntry.id))
            textView.setTypeface(null, Typeface.BOLD);
        else
            textView.setTypeface(null, Typeface.NORMAL);

        return v;
    }

    public Fragment fetchFragment(String id) {
        // Save the previous fragment in case an error happens after.
        String prevFragmentId = mCurrentFragmentId;

        // Set the current fragment.
        setCurrentFragment(id);

        if (mFragments.containsKey(id) && mFragments.get(id) != null) {
            return mFragments.get(id);
        }

        Fragment f;
        if (id.equals("audio")) {
            f = new AudioBrowserFragment();
        } else if (id.equals("video")) {
            f = new VideoGridFragment();
        } else if (id.endsWith("directories")) {
            f = new DirectoryViewFragment();
        } else if (id.equals("history")) {
            f = new HistoryFragment();
        } else {
            mCurrentFragmentId = prevFragmentId; // Restore the current fragment id.
            throw new IllegalArgumentException("Wrong fragment id.");
        }
        f.setRetainInstance(true);
        mFragments.put(id, f);
        return f;
    }

    private void setCurrentFragment(String id) {
        mCurrentFragmentId = id;
        this.notifyDataSetChanged();
    }

    /**
     * When Android has automatically recreated a fragment from the bundle state,
     * use this function to 'restore' the recreated fragment into this sidebar
     * adapter to prevent it from trying to create the same fragment again.
     *
     * @param id ID of the fragment
     * @param f The fragment itself
     */
    public void restoreFragment(String id, Fragment f) {
        if (f == null) {
            Log.e(TAG, "Can't set null fragment for " + id + "!");
            return;
        }
        mFragments.put(id, f);
        setCurrentFragment(id);
        // if Android added it, it's been implicitly added already...
    }
}