Android,원 각 ListView 효과 구현

10462 단어 Android원 각ListView
프로젝트 개발 에서 우 리 는 원 각 ListView 효 과 를 만 날 수 있 습 니 다.직각 이 보기 에는 그다지 우아 하지 않 기 때문에 여러분 들 은 그림 으로 이 루어 질 것 이 라 고 생각 할 수 있 습 니 다.상하 로 각각 세 장의 그림 을 만 들 려 고 합 니 다.이렇게 하 는 것 은 너무 번 거 롭 습 니 다.이때 shape 를 사용 하여 더욱 좋 은 실현 방식 을 실현 하 는 것 입 니 다.
먼저 Android 에서 Shape 의 사용법 을 살 펴 보 겠 습 니 다.
솔 리드
android:color 채 울 색 지정
gradient:그 라 데 이 션
android:startColor 와 android:endColor 는 각각 시작 과 끝 색 입 니 다.ndroid:angle 은 그 라 데 이 션 각도 이 고 45 의 정수 배 여야 합 니 다.
또한 그 라 데 이 션 기본 모드 는 android:type="linear",즉 선형 그 라 데 이 션 입 니 다.그 라 데 이 션 을 직경 방향 그 라 데 이 션 으로 지정 할 수 있 습 니 다.android:type="radial",직경 방향 그 라 데 이 션 은 반경 android:gradientRadius="50"을 지정 해 야 합 니 다.
stroke:테두리 그리 기
android:width="2dp"테두리 의 너비,android:color 테두리 의 색.
우 리 는 또한 테 두 리 를 점선 으로 그 리 는 형식 으로 설정 할 수 있다.설정 방식 은 다음 과 같다.
android:dashWidth="5dp"
android:dashGap="3dp"
그 중에서 안 드 로 이 드:dashWidth 는'-'와 같은 횡선 의 너 비 를 나타 내 고 안 드 로 이 드:dashGap 은 사이 의 거 리 를 나타 낸다.
코너:원 각
android:radius 는 각 의 라디안 으로 값 이 클 수록 각 이 둥 글 어 집 니 다.
물론 이 원 각 의 목록 한 단락 은 ListView 로 이 루어 진 것 이 아니 라 여러 개의 LinearLayout/RelativeLayout 로 접 혀 있 을 수 있 습 니 다.이것 은 네가 어떻게 취사선택 하 느 냐 에 달 려 있다.목록 항목 이 고정 적 으로 변 하지 않 으 면 후 자 를 이용 하여 실현 하 는 것 이 좋 으 며,동적 변화 가 필요 하 다 면 ListView 를 사용 하여 더욱 좋 습 니 다.
ListView 가 하나 밖 에 없 을 때의 배경 을 정의 합 니 다(위 아래 두 각 이 모두 원 각 입 니 다)applist_corner_round.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="rectangle" >
 
 <!--    -->
 <gradient
  android:angle="270"
  android:endColor="@color/white"
  android:startColor="@color/white" />
 
 <!--    -->
 <corners
  android:bottomLeftRadius="4dip"
  android:bottomRightRadius="4dip"
  android:topLeftRadius="4dip"
  android:topRightRadius="4dip" />
 
</shape>
ListView 첫 번 째 배경(위 는 원 각,아래 는 직각)applist_corner_round_top.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="rectangle" >
 
 <gradient
  android:angle="270"
  android:endColor="@color/white"
  android:startColor="@color/white" />
 
 <corners
  android:topLeftRadius="@dimen/app_list_radius"
  android:topRightRadius="@dimen/app_list_radius" />
 
</shape>
ListView 마지막 배경(위 는 직각,아래 는 원 각)applist_corner_round_bottom.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="rectangle" >
 
 <gradient
  android:angle="270"
  android:endColor="@color/white"
  android:startColor="@color/white" />
 
 <corners
  android:bottomLeftRadius="@dimen/app_list_radius"
  android:bottomRightRadius="@dimen/app_list_radius" />
 
</shape>
ListView 중간 항목 의 배경(위아래 모두 직각)applist_corner_round_center.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="rectangle" >
 
 <gradient
  android:angle="270"
  android:endColor="@color/white"
  android:startColor="@color/white" />
 
</shape>
다음은 Adapter 의 실현 을 살 펴 보 겠 습 니 다.

package com.example.roundcorner.adapter;
 
import java.util.List;
 
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
 
import com.example.roundcorner.R;
import com.example.roundcorner.entity.ListBean;
 
public class ListAdapter extends BaseAdapter {
 private List<ListBean> mList;
 private Context mContext;
 
 public ListAdapter(Context mContext,List<ListBean> mList) {
 this.mList = mList;
 this.mContext = mContext.getApplicationContext();
 }
 
 @Override
 public int getCount() {
 return this.mList.size();
 }
 
 @Override
 public Object getItem(int position) {
 return this.mList.get(position);
 }
 
 @Override
 public long getItemId(int position) {
 return position;
 }
 
 @Override
 public int getItemViewType(int position) {
 // TODO Auto-generated method stub
 return super.getItemViewType(position);
 }
 
 @Override
 public int getViewTypeCount() {
 // TODO Auto-generated method stub
 return super.getViewTypeCount();
 }
 
 @Override
 public View getView(int position, View convertView, ViewGroup parent) {
 ViewHolder holder = null;
 if (convertView == null) {
 holder = new ViewHolder();
 convertView = LayoutInflater.from(this.mContext).inflate(
  R.layout.listview_item, null, false);
 holder.textView = (TextView) convertView
  .findViewById(R.id.listview_item_textview);
 holder.imageView = (ImageView) convertView
  .findViewById(R.id.listview_item_imageview);
 convertView.setTag(holder);
 } else {
 holder = (ViewHolder) convertView.getTag();
 }
 
 if(position==0){
 
 if(position == getCount()-1){ //    
 convertView.setBackgroundResource(R.drawable.app_list_corner_round);
 }else{ //   
 convertView.setBackgroundResource(R.drawable.app_list_corner_round_top);
 }
 }else if(position == getCount()-1){
 convertView.setBackgroundResource(R.drawable.app_list_corner_round_bottom);
 }else{
 convertView.setBackgroundResource(R.drawable.app_list_corner_round_center);
 }
 
 ListBean lb = mList.get(position);
 holder.textView.setText(lb.getKey());
 
 return convertView;
 }
 
 static class ViewHolder {
 TextView textView;
 ImageView imageView;
 }
}
listview_item.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="wrap_content">
 
 <TextView
  android:id="@+id/listview_item_textview"
  android:layout_width="wrap_content"
  android:layout_height="48dp"
  android:paddingLeft="10dp"
  android:gravity="center_vertical"
  android:layout_centerVertical="true"
  android:text="A-H"
  android:textColor="@color/black"
  android:textSize="20sp" />
 
 <ImageView 
  android:id="@+id/listview_item_imageview"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:src="@drawable/arrow"
  android:layout_alignParentRight="true"
  android:layout_centerVertical="true"
  />
 
</RelativeLayout>
마지막 으로 메 인 화면 Activity 의 실현 을 살 펴 보 겠 습 니 다.

package com.example.roundcorner;
 
import java.util.ArrayList;
import java.util.List;
 
import android.app.Activity;
import android.os.Bundle;
import android.widget.ListView;
 
import com.example.roundcorner.adapter.ListAdapter;
import com.example.roundcorner.entity.ListBean;
 
public class MainActivity extends Activity {
 
 private List<ListBean> data;
 
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 
 initData();
 
 findView();
 }
 
 private void findView() {
 ListView mListView = (ListView) findViewById(R.id.mListView);
 
 ListAdapter mAdapter = new ListAdapter(this,data);
 mListView.setAdapter(mAdapter);
 }
 
 private void initData() {
 data = new ArrayList<ListBean>();
 for (int i = 0; i < 5; i++) {
 ListBean lb = new ListBean();
 lb.setKey("   "+i);
 data.add(lb);
 }
 }
 
}
activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context=".MainActivity" >
 
 <TextView
  android:layout_width="match_parent"
  android:layout_height="48dp"
  android:background="@color/white"
  android:gravity="center"
  android:text="  "
  android:textSize="20sp" />
 
 <RelativeLayout
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:padding="10dp" >
 
  <ListView
   android:id="@+id/mListView"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:background="@drawable/app_list_round"
   android:cacheColorHint="@android:color/transparent"
   android:divider="@drawable/app_list_divider"
   android:dividerHeight="2dip"
   android:padding="2dp" />
 </RelativeLayout>
 
</LinearLayout>
마지막 으로 이 루어 진 효 과 를 보 겠 습 니 다.

이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기