Android,원 각 ListView 효과 구현
먼저 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>
마지막 으로 이 루어 진 효 과 를 보 겠 습 니 다.이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.