메뉴 건너뛰기

조회 수 8759 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

현재 전화할 곳을 검색해서 필터링기능을 적용시켜 해당 문자열에 맞는 장소를 클릭하면 전화가 가게 하는 기능을 구현하였다.


전화번호가 저장되어있는 엑셀의 csv 파일을 읽어와서 리스트에 뿌려주는 형식으로 구현을 하였는데


csv 파일을 읽어와서 필터링을 거칠때 중요한 이슈는 "안녕하세요바보" 라는 문자열이 있으면 안녕 이라 검색을하면


"안녕하세요바보" 라고 바로나오지만 "바보" 라고 검색을하면 해당 문자열이 검색이 되지않는 문제점이 있었다.


하지만 문자열 자체가 "안녕하세요 바보" 라고 띄어쓰기가 적용되어 있으면 "바보" 라고 검색해도 해당 문자열이 검색이 되는걸


확인하였다. 그래서 모든 엑셀데이터는 검색이 용이하게 띄어쓰기를 알맞게 적용해 준뒤에 소스파일에 csv 파일을 추가시켰다.



EditText 를 통해서 텍스트가 변할때 바로 필터링을 적용해서 검색하는 기능을 만들기 위해서는


 EditText.addTextChangedListener(new TextWatcher() {

   @Override
   public void onTextChanged(CharSequence cs, int arg1, int arg2, int arg3) {
    // When user changed the Text
    // PhoneNumberActivity.this.adapter.getFilter().filter(cs); 원래 가져다 쓰는방법
    PhoneNumberActivity.this.getFilter().filter(cs); // 직접 구현

   }

   @Override
   public void beforeTextChanged(CharSequence arg0, int arg1, int arg2, int arg3) {
    // TODO Auto-generated method stub

   }

   @Override
   public void afterTextChanged(Editable s) {
    // TODO Auto-generated method stub
   }
  });


위에 검은색으로 찐하게 해놓은 부분은 ArrayAdapter 에서 구현되어 있는 부분을 가져다 쓰는부분이다.


이 기능으로는 필터링해서 보여주는 부분은 가능하지만 필터링 된 데이터를 가져다 쓰는데는 무리가 있었다.(내가 모르는 방법이 있을수도있다.)


그래서 adapter.getFilter().Filter(cs) 부분을 새롭게 구현해서 사용하였다.


먼저 해당 액티비티에서 implements Filterable 를 해주고 getFilter() 부분을 Override 시켜준 뒤



@Override
 public Filter getFilter() {
  // TODO Auto-generated method stub
  return myFilter;
 }

 Filter myFilter = new Filter() {

  @Override
  protected void publishResults(CharSequence constraint, FilterResults results) {
   // TODO Auto-generated method stub
   
   ArrayList<String> temp_list = new ArrayList<String>();
   
   call = (ArrayList<ListItem>) results.values; // 2) result 된 데이터를 받아온다
      
   for(int i=0; i<call.size(); i++){
    
    temp_list.add(call.get(i).getCall_name());
   
   }
   
   String[] products = (String[]) temp_list.toArray(new String[temp_list.size()]);
   adapter = new ArrayAdapter<String>(PhoneNumberActivity.this, R.layout.phone_list_item, R.id.product_name, products);
   lv.setAdapter(adapter); // 3) 필터링이 적용된 데이터를 listview에 set 시킨다
   
   if (results.count > 0) {
    adapter.notifyDataSetChanged();
   } else {
    adapter.notifyDataSetInvalidated();
   }
  }

  @Override
  protected FilterResults performFiltering(CharSequence prefix) {
   FilterResults results = new FilterResults();

            if (mOriginalValues == null) {
                synchronized (mLock) {
                    mOriginalValues = new ArrayList<ListItem>(call);
                }
            }

            if (prefix == null || prefix.length() == 0) {
                ArrayList<ListItem> list;
                synchronized (mLock) {
                    list = new ArrayList<ListItem>(mOriginalValues);
                }
                results.values = list;
                results.count = list.size();
            } else {
                String prefixString = prefix.toString().toLowerCase();

                ArrayList<ListItem> values;
                synchronized (mLock) {
                    values = new ArrayList<ListItem>(mOriginalValues);
                }

                final int count = values.size();
                final ArrayList<ListItem> newValues = new ArrayList<ListItem>();

                for (int i = 0; i < count; i++) {
                    final String valueName = values.get(i).getCall_name();
                    final String valueNumber = values.get(i).getCall_name();
                   
                    final String valueText = valueName.toString().toLowerCase();

                    // First match against the whole, non-splitted value
                    if (valueText.startsWith(prefixString)) {
                        newValues.add(new ListItem(valueName, valueNumber));
                    } else {
                        final String[] words = valueText.split(" ");
                        final int wordCount = words.length;

                        // Start at index 0, in case valueText starts with space(s)
                        for (int k = 0; k < wordCount; k++) {
                            if (words[k].startsWith(prefixString)) {
                                newValues.add(new ListItem(valueName, valueNumber));
                                break;
                            }
                        }
                    }
                }

                results.values = newValues;
                results.count = newValues.size();
            }

            return results; // 1) 필터링 적용 된 데이터를 보내준다 
  }
 };


이러한 식으로 새롭게 구현해서 해당 파일에 같이 구현해 준뒤에 사용을 하였다.

위와 같은 소스로 results에는 장소의이름 및 전화번호가 저장이 되게 되어

ArrayList 에 필터링 거친 데이터를 자유자재로 넣어서 요리 할 수 있게 구현하였다. 


 


List of Articles
번호 제목 날짜 조회 수
237 안드로이드 - 익명 클래스(Anonymous Class) 사용법 file 2021.03.31 281
236 안드로이드 - 문자열 리소스를 활용한 다국어 지원 file 2021.03.31 282
235 안드로이드 - SnackBar를 사용해 팝업창 띄우기 file 2021.03.31 282
234 안드로이드 - 옵션 메뉴 (Option Menu) 구현 방법 file 2021.04.01 283
233 초기화면 페이지를 만들어보자. splash 페이지 제작 file 2020.12.14 285
232 Java에서 XML 불러와서 동적 변화 주기 file 2021.03.31 288
231 줄바꿈 문자 치환 2020.12.14 289
230 [하이브리드앱] 링크를 웹뷰가 아닌 새로운 브라우저에서 열기 2021.09.30 293
229 패키지명을 한꺼번에 변경하기 (Refactor) file 2020.12.14 295
228 앱 번들(Android App Bundle) 만들기 file 2021.09.14 305
227 android.support.v4.content.FileProvider not found file 2020.12.14 308
226 안드로이드 - 리니어 레이아웃 (Linear Layout) file 2021.03.29 319
225 안드로이드 - 토스트(Toast) 메시지 사용하기. file 2021.03.31 321
224 안드로이드 - 뷰페이저(ViewPager) 구현 file 2021.04.02 323
223 안드로이드 - 명시적 인텐트(Explicit Intent)와 암시적 인텐트 (Implicit Intent) file 2021.04.01 324
222 안드로이드 앱배포하기 apk 만들기 file 2020.12.14 324
221 안드로이드 arrayList 를 Json으로 변환 / jsonarry file 2021.03.29 326
220 Firebase - 푸시알림 보내기 file 2021.09.30 339
219 안드로이드 - 버튼 이벤트 처리방법 정리 (리스너 구현 및 이벤트 핸들링) file 2021.03.31 343
218 Volley 이용시에 한글 깨질때 UTF-8로 변경 2020.12.14 343
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 13 Next
/ 13

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved