회원가입아이디/비번찾기
실시간 TV
홈으로
Custom ListView (커스텀 리스트뷰) Footer를 이용한 더보기 구현
7년 전
리스트뷰의 더보기 기능 구현입니다.

추가적으로 커스텀으로 만들었습니다. 소스를 어디서 훔쳐온건지는...기억이 안나... 링크를 못달아둡니다.ㅠ

혹시라도 자료에 문제가 있거나, 삭제를 요청 혹은 출처를 아시는 분은 댓글을 달아주시기 바랍니다.



커스텀 리스트뷰 + footer를 이용한 더보기 구현 (샘플소스 다운로드 및 스크린샷은 소스 하단부에 있습니다.)

MainActivity.java

package com.example.morelistview;

import java.util.ArrayList;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends Activity implements OnScrollListener
{
    private ArrayList marItem;
    private MyListAdapter     mMyAdapte;
    private ListView          mListView;
    private MyItem            items;
  
    // 스크롤 로딩
    private LayoutInflater mInflater;
    private boolean mLockListView;

    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
      
        mListView = (ListView)findViewById(R.id.moreList);
        marItem = new ArrayList();
      
        mLockListView = true;
      
        // 푸터를 등록. setAdapter 이전에 해야함.
        mInflater = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        mListView.addFooterView(mInflater.inflate(R.layout.listview_footer, null));
      
        // 스크롤 리스너 등록
        mListView.setOnScrollListener(this);
      
        mMyAdapte = new MyListAdapter(this, R.layout.custom_layout, marItem);
        mListView.setAdapter(mMyAdapte);
      
        // 임시 데이터 등록
        addItems(10);
    }
  
    // dialog
    private void btnDialog(final Activity _activity, String msg, final boolean _slct, final String _slctCustId)
    {
        AlertDialog.Builder alt_bld = new AlertDialog.Builder(_activity);
        alt_bld.setMessage(msg).setCancelable(false)
        .setPositiveButton("확인", new DialogInterface.OnClickListener()
        {
            public void onClick(DialogInterface dialog, int id)
            {
                if(_slct)
                {
                    Toast.makeText(MainActivity.this, "확인", 1).show();
                }
                else if(!_slct)
                {
                    Toast.makeText(MainActivity.this, "취소", 1).show();
                }
            }
        })
        .setNegativeButton("취소", new DialogInterface.OnClickListener()
        {
            public void onClick(DialogInterface dialog, int id)
            {
            }
        });
        AlertDialog alert = alt_bld.create();
        alert.show();
    }

    // 리스트뷰 출력 항목
    class MyItem
    {
        MyItem(String _coustId)
        {
            sCustId = _coustId;
        }
        String sCustId;
    }
  
    // 어댑터 클래스
    class MyListAdapter extends BaseAdapter
    {
        Context cContext;
        LayoutInflater lInflater;
        ArrayList alSrc;
        int layout;
      
        public MyListAdapter(Context _context, int _layout, ArrayList _arrayList)
        {
            cContext  = _context;
            lInflater = (LayoutInflater)_context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            alSrc     = _arrayList;
            layout    = _layout;
        }

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

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

        @Override
        public long getItemId(int position)
        {
            return position;
        }

        // 각 뷰의 항목 생성
        @Override
        public View getView(int position, View convertView, ViewGroup parent)
        {
            final int pos = position;
            if(convertView == null)
            {
                convertView = lInflater.inflate(layout, parent, false);
            }
          
            final String getCustId = alSrc.get(pos).sCustId;
          
            TextView tvCustId = (TextView)convertView.findViewById(R.id.tvCoustId);
            tvCustId.setText(alSrc.get(position).sCustId);
          
            Button btSending = (Button)convertView.findViewById(R.id.sendBtn);
            btSending.setOnClickListener(new OnClickListener()
            {
                @Override
                public void onClick(View v)
                {
                    btnDialog(MainActivity.this, "전송", true, getCustId);
                }
            });
            // 삭제버튼
            Button deleteBtn = (Button)convertView.findViewById(R.id.deleteBtn);
            deleteBtn.setOnClickListener(new OnClickListener()
            {
                @Override
                public void onClick(View v)
                {
                    btnDialog(MainActivity.this, "삭제", false, getCustId);
                }
            });
            return convertView;
        }
    }
  
    // 더미 아이템 추가
    private void addItems(final int size)
    {
        // 아이템을 추가하는 동안 중복 요청을 방지하기 위해 락을 걸어둡니다.
        mLockListView = true;
        Runnable run = new Runnable()
        {
            @Override
            public void run()
            {
                for(int i = 0 ; i < size ; i++)
                    {
                    items = new MyItem("more " + i);
                    marItem.add(items);
                    }
                // 모든 데이터를 로드하여 적용하였다면 어댑터에 알리고
                // 리스트뷰의 락을 해제합니다.
                mMyAdapte.notifyDataSetChanged();
                mLockListView = false;
            }
        };
        // 속도의 딜레이를 구현하기 위한 꼼수
        Handler handler = new Handler();
        handler.postDelayed(run, 1000);
    }

    public void onBtnClickBackBtn(View _view)
    {
        finish();
    }
    @Override
    public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount)
    {
        // 현재 가장 처음에 보이는 셀번호와 보여지는 셀번호를 더한값이
        // 전체의 숫자와 동일해지면 가장 아래로 스크롤 되었다고 가정합니다.
        int count = totalItemCount - visibleItemCount;
      
        if(firstVisibleItem >= count && totalItemCount != 0 && mLockListView == false)
        {
          Log.i("list", "Loading next items");
          addItems(10);
        }  
    }
    @Override
    public void onScrollStateChanged(AbsListView view, int scrollState)
    {
    }
}


activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:orientation="vertical" >

    <ListView
       android:id="@+id/moreList"
       android:layout_width="match_parent"
       android:layout_height="match_parent" >
    </ListView>

</LinearLayout>

custom_layout.xml



<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:orientation="horizontal" >

    <TextView
       android:id="@+id/tvCoustId"
       android:layout_width="0dip"
       android:layout_height="wrap_content"
       android:layout_weight="6"
       android:text="Medium Text"
       android:textAppearance="?android:attr/textAppearanceMedium" />

    <Button
       android:id="@+id/sendBtn"
       android:layout_width="0dip"
       android:layout_height="wrap_content"
       android:layout_weight="2"
       android:text="확인" />

    <Button
       android:id="@+id/deleteBtn"
       android:layout_width="0dip"
       android:layout_height="wrap_content"
       android:layout_weight="2"
       android:text="취소" />

</LinearLayout>
listview_footer.xml




<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="fill_parent"
   android:layout_height="wrap_content"
   android:gravity="center" >

    <ImageView
       android:id="@+id/iv_list_footer_loading"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content" />

    <TextView
       android:id="@+id/tv_list_footer"
       android:layout_width="wrap_content"
       android:layout_height="50dip"
       android:layout_marginLeft="10dip"
       android:gravity="center"
       android:text="More item ..."
       android:textAppearance="?android:attr/textAppearanceLarge" />

</LinearLayout>
추천추천 : 1127 추천 목록
번호 제목
1,346
 윈도우 서버 2019 취약점 점검 보안
1,345
 윈도우 서버 2019 취약점 점검 보안 (windows server 2019)
1,344
 Windows 취약점진단 보안가이드라인
1,343
 Windows Admin Center를 통한 서버 관리
1,342
 윈도우 서버에서 실행되는 서비스 확인
1,341
 Chrome NET::ERR CERT REVOKED 해결방법
1,340
 cmd 명령어 (명령 프롬프트 명령어) 모음
1,339
 Windows10 특정 프로그램(OCS 2007 R2)에서 첨부파일 드래그앤드롭이 안 되는 현상
1,338
 윈도우 로그, 관리 이벤트 삭제
1,337
 클린 부팅
1,336
 Windows 구성 요소 저장소에서 파일 손상 검사
1,335
 Windows Defender 검사 기록 삭제하기
1,334
 간단한 윈도우 10 정품 인증 (크랙프로그램 필요없음)
1,333
 오류난 폴더 강제삭제 방법
1,332
 크롬에서 플래시 항상 허용하도록 설정하기 (레지스트리) reg 파일 만들기
1,331
 GPT 디스크를 MBR 디스크로 변환
1,330
 MBR 디스크를 GPT 디스크로 변환
1,329
 구글 검색을 200% 활용하게 해주는 검색 명령어 총정리
1,328
 [Jquery] jQuery로 우클릭 방지, 드래그 방지, 선택 방지 (IE10, 파이어폭스, 크롬 확인)
1,327
 php 사용자 접속IP, 브라우저정보, os정보, http, https 접속프로토콜 알아오기
1,326
 [PHP] IE 브라우저 접속 검출하기
1,325
 윈도우10 시스템 예약 파티션 확인 및 삭제
1,324
 윈도우10 복구 파티션 삭제 방법
1,323
 윈도우10 부팅지연 검은화면에서 몇분간 머무는 현상 해결방법
1,322
 삼성노트북 바이오스 진입이 불가능한 경우 바이오스 재설치와 NVRAM 초기화
1,321
 익스플로러(IE)의 구글 검색공급자 한글로 변경 방법
1,320
 윈도우 10 기본 앱 삭제 및 복구
1,319
 meta 태그 http-equiv 설정방법과 차이점
1,318
 구글(Google)검색에서 고급연산자를 이용하여 많은 정보를 얻는 방법
1,317
 프로그램 없이 하드디스크 복사 및 백업하기
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright ⓒ musictrot All rights reserved.