Android UI 컨트롤 의 ListView 원 각 효과 구현

오늘 안 드 로 이 드 그룹 에서 누군가가 원 각 ListView 의 실현 방식 을 다시 구 했 는데 마침 자신 이 이전에 실현 한 적 이 있다.그래서 현재 이 를 실현 하 는 방식 을 블 로그 에 써 서 타인 의 공 부 를 공유 했다.실현 방식 을 제시 하기 전에 자신의 생각 을 덧 붙 이 는 것 은 안 드 로 이 드 의 사각형 인 ListView 가 너무'딱딱 하 다'는 느낌 이 들 고 원 각 이 없 는 친화력 이 있다.애플 도'원 각'이라는 디자인 을 위해 특 허 를 신청 했다.
아무래도 원 각 이 요즘 사람들의 취향 에 맞 는 것 같 습 니 다.
낡은 규칙 에 따라 먼저 두 장의 효과 도 를 올 려 라.
첫 번 째:

두 번 째 장:

이 방식 은 주로 자신의 ListView 코드 를 다음 과 같이 다시 실현 해 야 합 니 다.

package com.kiritor.corner_listview; 
 
 
import android.content.Context; 
import android.util.AttributeSet; 
import android.view.MotionEvent; 
import android.widget.AdapterView; 
import android.widget.ListView; 
 
/*** 
 *    listview 
 * 
 * @author Kiritor 
 * 
 */ 
public class MyListView extends ListView { 
 public MyListView(Context context) { 
  super(context); 
 } 
 
 public MyListView(Context context, AttributeSet attrs) { 
  super(context, attrs); 
 } 
 
 /**** 
  *        
  */ 
 @Override 
 public boolean onTouchEvent(MotionEvent ev) { 
  switch (ev.getAction()) { 
  case MotionEvent.ACTION_DOWN: 
   int x = (int) ev.getX(); 
   int y = (int) ev.getY(); 
   int itemnum = pointToPosition(x, y); 
   if (itemnum == AdapterView.INVALID_POSITION) 
    break; 
   else { 
    if (itemnum == 0) { 
     if (itemnum == (getAdapter().getCount() - 1)) { 
      //       ,           
      setSelector(R.drawable.list_round); 
     } else { 
      //    ,          
      setSelector(R.drawable.list_top_round); 
     } 
    } else if (itemnum == (getAdapter().getCount() - 1)) 
     //     ,          
     setSelector(R.drawable.list_bottom_round); 
    else { 
     //    ,        
     setSelector(R.drawable.list_center_round); 
    } 
   } 
   break; 
  case MotionEvent.ACTION_UP: 
   break; 
  } 
  return super.onTouchEvent(ev); 
 } 
} 
MainActivity

package com.kiritor.corner_listview; 
 
import java.util.ArrayList; 
import java.util.HashMap; 
import java.util.Map; 
 
 
 
import android.app.Activity; 
import android.os.Bundle; 
import android.view.View; 
import android.view.ViewGroup; 
import android.view.Window; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
import android.widget.ArrayAdapter; 
import android.widget.ListAdapter; 
import android.widget.ListView; 
import android.widget.SimpleAdapter; 
import android.widget.Toast; 
 
public class MainActivity extends Activity implements OnItemClickListener { 
 private MyListView listView_1, listView_2, listView_3; 
 private ArrayList<Map<String, String>> listData, listData2, listData3; 
 private SimpleAdapter adapter; 
 
 @Override 
 public void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  requestWindowFeature(Window.FEATURE_NO_TITLE); 
  setContentView(R.layout.main); 
  listView_1 = (MyListView) findViewById(R.id.mylistview_1); 
  listView_2 = (MyListView) findViewById(R.id.mylistview_2); 
  listView_3 = (MyListView) findViewById(R.id.mylistview_3); 
 
  listView_1.setAdapter(getSimpleAdapter_1()); 
  listView_2.setAdapter(getSimpleAdapter_2()); 
  listView_3.setAdapter(getSimpleAdapter_3()); 
 
  listView_1.setOnItemClickListener(this); 
  listView_2.setOnItemClickListener(this); 
  listView_3.setOnItemClickListener(this); 
 
  setListViewHeightBasedOnChildren(listView_1); 
  setListViewHeightBasedOnChildren(listView_2); 
  setListViewHeightBasedOnChildren(listView_3); 
 } 
 
 /** 
  *         
  */ 
 private SimpleAdapter getSimpleAdapter_1() { 
  listData = new ArrayList<Map<String, String>>(); 
 
  Map<String, String> map = new HashMap<String, String>(); 
  map.put("text", "    "); 
  listData.add(map); 
 
  map = new HashMap<String, String>(); 
  map.put("text", "     "); 
  listData.add(map); 
 
  return new SimpleAdapter(MainActivity.this, listData, 
    R.layout.list_item, new String[] { "text" }, 
    new int[] { R.id.tv_list_item }); 
 
 } 
 
 /** 
  *         
  */ 
 private SimpleAdapter getSimpleAdapter_2() { 
  listData2 = new ArrayList<Map<String, String>>(); 
 
  Map<String, String> map = new HashMap<String, String>(); 
  map.put("text", "    "); 
  listData2.add(map); 
 
  map = new HashMap<String, String>(); 
  map.put("text", "    "); 
  listData2.add(map); 
 
  map = new HashMap<String, String>(); 
  map.put("text", "    "); 
  listData2.add(map); 
 
  map = new HashMap<String, String>(); 
  map.put("text", "     "); 
  listData2.add(map); 
 
  map = new HashMap<String, String>(); 
  map.put("text", "    "); 
  listData2.add(map); 
 
  return new SimpleAdapter(MainActivity.this, listData2, 
    R.layout.list_item, new String[] { "text" }, 
    new int[] { R.id.tv_list_item }); 
 
 } 
 
 /** 
  *         
  */ 
 private SimpleAdapter getSimpleAdapter_3() { 
  listData3 = new ArrayList<Map<String, String>>(); 
 
  Map<String, String> map = new HashMap<String, String>(); 
  map.put("text", "     "); 
  listData3.add(map); 
 
  map = new HashMap<String, String>(); 
  map.put("text", "    "); 
  listData3.add(map); 
 
  map = new HashMap<String, String>(); 
  map.put("text", "  "); 
  listData3.add(map); 
 
  map = new HashMap<String, String>(); 
  map.put("text", "  "); 
  listData3.add(map); 
 
  return new SimpleAdapter(MainActivity.this, listData3, 
    R.layout.list_item, new String[] { "text" }, 
    new int[] { R.id.tv_list_item }); 
 
 } 
 
 /*** 
  *     listview    
  * 
  * @param listView 
  */ 
 public void setListViewHeightBasedOnChildren(ListView listView) { 
  ListAdapter listAdapter = listView.getAdapter(); 
  if (listAdapter == null) { 
   return; 
  } 
  int totalHeight = 0; 
  for (int i = 0; i < listAdapter.getCount(); i++) { 
   View listItem = listAdapter.getView(i, null, listView); 
   listItem.measure(0, 0); 
   totalHeight += listItem.getMeasuredHeight(); 
  } 
  ViewGroup.LayoutParams params = listView.getLayoutParams(); 
  params.height = totalHeight 
    + (listView.getDividerHeight() * (listAdapter.getCount() - 1)); 
  // params.height += 5;// if without this statement,the listview will be 
  // a 
  // little short 
  // listView.getDividerHeight()              
  // params.height      ListView          
  listView.setLayoutParams(params); 
 } 
 
 @Override 
 public void onItemClick(AdapterView<?> parent, View view, int position, 
   long id) { 
   
  if (parent == listView_1) { 
   Map<String, String> map = listData.get(position); 
   Toast.makeText(MainActivity.this, map.get("text"), 1).show(); 
  } else if (parent == listView_2) { 
   Map<String, String> map = listData2.get(position); 
   Toast.makeText(MainActivity.this, map.get("text"), 1).show(); 
  } else if (parent == listView_3) { 
   Map<String, String> map = listData3.get(position); 
   Toast.makeText(MainActivity.this, map.get("text"), 1).show(); 
  } 
 
 } 
 
} 
거의 다 르 지 않다.바로 이렇다.그리고 관련 자원 파일 도 있다.

여 기 는 일일이 드 리 지 않 겠 습 니 다. 
전체 소스 코드 부분:ListView 원 각 효과 구현
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기