5

1つのアクティビティに2つのリストビューを入力したいと思います。そのために、1つのレイアウトに2つのリストビューを配置しました。私の問題は、両方のリストビューにデータが入力されているのに、1つのリストビューしか表示されていないことです。これで、1つのレイアウトを非表示にすると、別のリストビューが表示されます。

ここに私のxmlファイルを投稿しています。レイアウトに問題はありますか?解決策を提案してください。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical"
    android:paddingTop="10dp"
    android:id="@+id/playlist_lyt"
    >

    <Button 
        android:id="@+id/btnAlbumwise"
        android:text="View Albumwise"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"        
        />

    <RelativeLayout 
        android:id="@+id/layout_songlist"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical"
        android:paddingTop="10dp"
        android:layout_below="@+id/layout_albumlist"  
        >

        <EditText android:id="@+id/inputSearch"
            android:layout_width="fill_parent"
            android:layout_height="33dp"
            android:hint="Search.."
            android:inputType="textVisiblePassword"
            android:cursorVisible="false"
            android:background="@drawable/rounded_edittext" 
            android:layout_marginLeft="5dp"
            android:layout_marginRight="5dp"            
        />

        <ListView
            android:id="@android:id/list"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:divider="#000000"
            android:dividerHeight="4dp"
            android:listSelector="@drawable/list_selector"
            android:layout_below="@+id/inputSearch" 
            android:paddingTop="8dp"/>

    </RelativeLayout>

    <RelativeLayout
        android:id="@+id/layout_albumlist"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical"
        android:paddingTop="10dp"
        android:layout_below="@+id/btnAlbumwise"        
        >

         <ListView  
            android:id="@+id/liist"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:divider="#242424"
            android:dividerHeight="1dp"
            android:listSelector="@drawable/list_selector"
        />
    </RelativeLayout>
</RelativeLayout>

リストビュー「liist」に入力するコード。PlaylistActivity.java

      Cursor cursor1 = managedQuery(MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI, null,null, null, null);
      if (cursor1 == null) 
      {
          //Query Failed , Handle error.
      }
      else if (!cursor1.moveToFirst()) 
      {
         //No media on the device.
      }
      else
      {   
        //  int albumName = cursor.getColumnIndex(MediaStore.Audio.Albums.ALBUM);
          int id = cursor1.getColumnIndex(MediaStore.Audio.Albums._ID);
          int albumartist = cursor1.getColumnIndex(MediaStore.Audio.Albums.ARTIST);

          for(int i=0;i<cursor1.getCount();i++)
          {
                String Name = cursor1.getString(cursor1.getColumnIndex(MediaStore.Audio.Albums.ALBUM));
                Integer albumid = cursor1.getInt(id);                       
                String artist = cursor1.getString(albumartist);

                Bitmap bitmap = null;
                bitmap = getArtwork(context, albumid);
                    lstImage.add(bitmap);
                    lstName.add(Name);
                    lstArtist.add(artist);

                cursor1.moveToNext();
           }
       }
       cursor1.close();                    

       rowItems = new ArrayList<RowItem>();
        for (int i = 0; i < lstName.size(); i++) {
            RowItem item = new RowItem(lstImage.get(i), lstName.get(i) , lstArtist.get(i));
            rowItems.add(item);
        }          
        CustomListViewAdapter adapter = new CustomListViewAdapter(PlayListActivity.this,
                R.layout.list_item, rowItems);
        lv1.setAdapter(adapter);
        lv1.setOnItemClickListener(new OnItemClickListener() {

            public void onItemClick(AdapterView<?> parent, View view,
                    int position, long id) {
                // TODO Auto-generated method stub
                RowItem item = rowItems.get(position);
                String title = item.getTitle();
                Intent in = new Intent(PlayListActivity.this,AlbumsongListActivity.class);

                // Sending songIndex to PlayerActivity
                in.putExtra("albumTitle", title);
                in.putExtra("list", 0);
                in.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                startActivity(in);

            }
        });

アイテムをクリックすると、別のアクティビティAlbumsonglistactivity.javaが開始されます。

public class AlbumsongListActivity extends ListActivity {
@Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
String[] from = { "songTitle", "artist" };
        int[] to = { R.id.album_songTitle, R.id.album_songArtist };
        adapter = new SimpleAdapter(this, getAlbumSongList(context),
                R.layout.albumsonglist_item, from, to) 
        {
            public long getItemId(int position) 
            {
                return songsListData.indexOf(getItem(position));
            }
        };

        setListAdapter(adapter);
        ListView lv = getListView();
        lv.setOnItemClickListener(new OnItemClickListener() 
        {
            public void onItemClick(AdapterView<?> parent, View view,
                    int position, long id) 
            {
                // getting listitem index
                int songIndex = (int) id;

                // Starting new intent
                Intent in = new Intent(getApplicationContext(),MusicPlayertemp.class);
                in.putExtra("songIndex", songIndex);
                in.putExtra("albumtitle", albumName);
                in.putExtra("listFlag", 3);
                startActivity(in);              
            }
        });
    }

    public ArrayList<HashMap<String, String>> getAlbumSongList(Context c) 
    {
        String whereClause = MediaStore.Audio.Media.ALBUM + " = ? ";
        String s[] = new String[] { albumName };
        Cursor cursor = c.getContentResolver().query(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, null, whereClause,s, MediaStore.Audio.Media.TITLE);
        if (cursor == null) 
        {
            // Query Failed , Handle error.
        } 
        else if (!cursor.moveToFirst()) 
        {
            // No media on the device.
        } 
        else 
        {
            int titleColumn = cursor.getColumnIndex(android.provider.MediaStore.Audio.Media.TITLE);
            int idColumn = cursor.getColumnIndexOrThrow(android.provider.MediaStore.Audio.Media.DATA);
            int artistcolumn = cursor.getColumnIndex(android.provider.MediaStore.Audio.Media.ARTIST);
            albumid = cursor.getInt(cursor.getColumnIndex(android.provider.MediaStore.Audio.Media.ALBUM_ID));
            int id = cursor.getColumnIndex(android.provider.MediaStore.Audio.Media._ID);
            for (int i = 0; i < cursor.getCount(); i++) 
            {
                String thisTitle = cursor.getString(titleColumn);
                String path = cursor.getString(idColumn);
                String artist = cursor.getString(artistcolumn);         
                String ID = cursor.getString(id);
                HashMap<String, String> song = new HashMap<String, String>();
                song.put("songTitle", thisTitle);
                song.put("songPath", path);
                song.put("artist", artist);
                song.put("id", ID);
                // Adding each song to SongList
                songsList.add(song);
                cursor.moveToNext();
            }
        }
        // looping through playlist
        for (int i = 0; i < songsList.size(); i++) 
        {
            // creating new HashMap
            HashMap<String, String> song = songsList.get(i);
            // adding HashList to ArrayList
            songsListData.add(song);
        }
        return songsListData;
    }

albumsonglistActivityで、アイテムをクリックしても呼び出されません。

4

6 に答える 6

5

最初のレイアウトの下に別のレイアウトを設定していて、最初のレイアウトが fill_parent の高さを取るため、これが問題です。

線形レイアウトを使用し、両方のリストビューをその中に配置し、layout_weight プロパティを使用して両方のリストビューを同じ高さにする必要があります。

たとえば、階層の下をたどることができます。オリジナルのコードではなく、レイアウトの開発に使用できる単なる構造です

<LinearLayout orientation="verical">
   <ListView layout_weight=1></ListView>   
   <ListView layout_weight=1></ListView>
</LinearLayout>
于 2013-01-17T11:45:56.150 に答える
3

追加

android:layout_weight = "1" 

RelativeLayoutsを含む両方にlistView

于 2013-01-17T11:46:55.957 に答える
3

android:layout_height="fill_parent"あなたは両方の相対レイアウトに与えました。これが、両方のリストビューを表示できない理由です。

線形レイアウトを使用し、重みを使用して画面を分割して両方のリストビューを表示できます

于 2013-01-17T11:42:45.523 に答える
2

2 番目のレイアウトは fill_parent で、最初のレイアウトはその下に配置されます。だから見ることは不可能です。

私はあなたがこのようなものが欲しいと仮定します

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/playlist_lyt"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical"
    android:paddingTop="10dp" >

    <Button
        android:id="@+id/btnAlbumwise"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="View Albumwise" />

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical"
        android:paddingTop="10dp"
        android:weightSum="1" >

        <RelativeLayout
            android:id="@+id/layout_albumlist"
            android:layout_width="fill_parent"
            android:layout_height="0dp"
            android:layout_weight="0.5" >

            <ListView
                android:id="@+id/liist"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:divider="#242424"
                android:dividerHeight="1dp"
                android:listSelector="@drawable/list_selector" />
        </RelativeLayout>

        <RelativeLayout
            android:id="@+id/layout_songlist"
            android:layout_width="fill_parent"
            android:layout_height="0dp"
            android:layout_weight="0.5" >

            <EditText
                android:id="@+id/inputSearch"
                android:layout_width="fill_parent"
                android:layout_height="33dp"
                android:layout_marginLeft="5dp"
                android:layout_marginRight="5dp"
                android:background="@drawable/rounded_edittext"
                android:cursorVisible="false"
                android:hint="Search.."
                android:inputType="textVisiblePassword" />

            <ListView
                android:id="@android:id/list"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:layout_below="@+id/inputSearch"
                android:divider="#000000"
                android:dividerHeight="4dp"
                android:listSelector="@drawable/list_selector"
                android:paddingTop="8dp" />
        </RelativeLayout>

    <RelativeLayout>
</RelativeLayout>
于 2013-01-17T11:46:57.673 に答える
2

このようにコードを更新してみてください

<RelativeLayout 
    android:id="@+id/layout_songlist"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:paddingTop="10dp"
    android:layout_below="@+id/layout_albumlist"  
    >

    <EditText android:id="@+id/inputSearch"
        android:layout_width="fill_parent"
        android:layout_height="33dp"
        android:hint="Search.."
        android:inputType="textVisiblePassword"
        android:cursorVisible="false"
        android:background="@drawable/rounded_edittext" 
        android:layout_marginLeft="5dp"
        android:layout_marginRight="5dp"            
    />

    <ListView
        android:id="@android:id/list"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:divider="#000000"
        android:dividerHeight="4dp"
        android:listSelector="@drawable/list_selector"
        android:layout_below="@+id/inputSearch" 
        android:paddingTop="8dp"/>

</RelativeLayout>

<RelativeLayout
    android:id="@+id/layout_albumlist"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:paddingTop="10dp"
    android:layout_below="@+id/btnAlbumwise"        
    >

     <ListView  
        android:id="@+id/liist"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:divider="#242424"
        android:dividerHeight="1dp"
        android:listSelector="@drawable/list_selector"
    />
</RelativeLayout>
于 2013-01-17T11:43:12.347 に答える
0

これに対する最善の解決策は、カスタム ScrollView を作成し、それを使用し<ScrollView>て < in.parx.VerticalScrollView>に置き換えることです。

VerticalScrollView.java には以下を使用します

import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.widget.ScrollView;

public class VerticalScrollView extends ScrollView{

    public VerticalScrollView(Context context) {
        super(context);
    }

    public VerticalScrollView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public VerticalScrollView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        final int action = ev.getAction();
        switch (action)
        {
            case MotionEvent.ACTION_DOWN:
                Log.i("VerticalScrollview", "onInterceptTouchEvent: DOWN super false" );
                super.onTouchEvent(ev);
                break;

            case MotionEvent.ACTION_MOVE:
                return false; // redirect MotionEvents to ourself

            case MotionEvent.ACTION_CANCEL:
                Log.i("VerticalScrollview", "onInterceptTouchEvent: CANCEL super false" );
                super.onTouchEvent(ev);
                break;

            case MotionEvent.ACTION_UP:
                Log.i("VerticalScrollview", "onInterceptTouchEvent: UP super false" );
                return false;

            default: Log.i("VerticalScrollview", "onInterceptTouchEvent: " + action ); break;
        }

        return false;
    }

    @Override
    public boolean onTouchEvent(MotionEvent ev) {
        super.onTouchEvent(ev);
        Log.i("VerticalScrollview", "onTouchEvent. action: " +ev.getAction());
        return true;
    }
}
于 2016-10-17T15:22:03.207 に答える