Android使用RecyclerView實(shí)現(xiàn)投票系統(tǒng)
本文實(shí)例為大家分享了Android投票系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
一、創(chuàng)建一個(gè)fragment_vote_list.xml用來(lái)顯示投票的主頁(yè)面
(1)標(biāo)題欄使用Toolbar
(2)投票區(qū)域可以滑動(dòng),使用RecyclerView實(shí)現(xiàn)
<?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="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:clickable="true"
android:background="@color/backgroundColorWhite">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/backgroundColorWhite"
android:orientation="vertical">
<android.support.v7.widget.Toolbar
android:id="@+id/vote_list_toolbar"
android:layout_width="match_parent"
android:layout_height="@dimen/toolbarHeight"
android:background="@color/backgroundColorWhite"
app:contentInsetStart="0dp">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/vote_list_back_btn"
android:layout_width="@dimen/titleBarBackWidth"
android:layout_height="@dimen/titleBarBackHeight"
android:layout_margin="@dimen/margin_min"
android:layout_centerVertical="true"
android:background="@drawable/titlebar_back"
android:layout_marginLeft="@dimen/padding_20"
/>
<TextView
android:id="@+id/vote_list_title_tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:layout_gravity="center_vertical"
android:text="投票"
android:textColor="@color/textcolor_28282d"
android:textSize="@dimen/textSizeMax"
android:textStyle="bold"/>
</RelativeLayout>
</android.support.v7.widget.Toolbar>
<android.support.v7.widget.RecyclerView
android:id="@+id/vote_list_recycleview"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
</RelativeLayout>
注:界面字體大小以及控件寬度自行調(diào)整即可,使用RecyclerView首先需要在項(xiàng)目的build.gradle中添加相應(yīng)的依賴庫(kù)才行。添加:implementation ‘com.android.support:recyclerview-v7:24.2.1'
界面效果:

二、創(chuàng)建一個(gè)item_vote.xml用來(lái)顯示投票的具體內(nèi)容
(1)主布局使用LinearLayout實(shí)現(xiàn),里面添加一個(gè)TextView用來(lái)顯示投票的問(wèn)題,使用CheckBox作為投票的多選框。
(2)將當(dāng)前的Item加載到投票的主頁(yè)面中
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@color/backgroundColorWhite" > <TextView android:id="@+id/item_vote_question_tv" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="1.請(qǐng)問(wèn)你支持哪一個(gè)決議?" android:textColor="@color/black" android:textSize="@dimen/item_vote_question" android:layout_marginLeft="@dimen/padding_20" /> <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@color/backgroundColorWhite" android:orientation="vertical" android:layout_margin="@dimen/padding_20"> <CheckBox android:id="@+id/item_vote_answer1_cb" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="AAAAAA" android:textColor="@color/black" android:textSize="@dimen/item_vote_answer" /> <CheckBox android:id="@+id/item_vote_answer2_cb" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="BBBBBBB" android:textColor="@color/black" android:textSize="@dimen/item_vote_answer" /> <CheckBox android:id="@+id/item_vote_answer3_cb" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="BCCCCC" android:textColor="@color/black" android:textSize="@dimen/item_vote_answer" /> </LinearLayout> </LinearLayout>
界面效果:

三、創(chuàng)建一個(gè)投票信息實(shí)體類(lèi)作為適配器的適配類(lèi)型,新建VoteInfo.java類(lèi)。
public class VoteInfo {
private String questionItem;
private String[] answerItems;
public VoteInfo(String questionItem,String[] answerItems){
this.questionItem=questionItem;
this.answerItems=answerItems;
}
public String getQuestionItem(){
return questionItem;
}
public String[] getAnswerItems(){
return answerItems;
}
}
四、接下來(lái)需要為RecyclerView準(zhǔn)備一個(gè)適配器,新建VoteInfoAdapter.java,讓這個(gè)適配器繼承自RecyclerView.Adapter,并將泛型指定為VoteInfoAdapter.ViewHolder。其中,ViewHolder是我們?cè)赩oteInfoAdapter中定義的一個(gè)內(nèi)部類(lèi)。
public class VoteInfoAdapter extends RecyclerView.Adapter<VoteInfoAdapter.ViewHolder> {
private List<VoteInfo> mVoteInfoList;
@Override
public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view= LayoutInflater.from(parent.getContext()).inflate(R.layout.item_vote,parent,false);
ViewHolder holder=new ViewHolder(view);
return holder;
}
@Override
public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
VoteInfo voteInfo=mVoteInfoList.get(position);
holder.questionItem.setText(voteInfo.getQuestionItem());
holder.answerItem_1.setText(voteInfo.getAnswerItems()[0]);
holder.answerItem_2.setText(voteInfo.getAnswerItems()[1]);
holder.answerItem_3.setText(voteInfo.getAnswerItems()[2]);
}
@Override
public int getItemCount() {
return mVoteInfoList.size();
}
static class ViewHolder extends RecyclerView.ViewHolder{
TextView questionItem;
CheckBox answerItem_1;
CheckBox answerItem_2;
CheckBox answerItem_3;
public ViewHolder(View itemView) {
super(itemView);
questionItem=(TextView)itemView.findViewById(R.id.item_vote_question_tv);
answerItem_1=(CheckBox)itemView.findViewById(R.id.item_vote_answer1_cb);
answerItem_2=(CheckBox)itemView.findViewById(R.id.item_vote_answer2_cb);
answerItem_3=(CheckBox)itemView.findViewById(R.id.item_vote_answer3_cb);
}
}
public VoteInfoAdapter(List<VoteInfo> voteInfoList){
mVoteInfoList=voteInfoList;
}
}
五、適配器已經(jīng)準(zhǔn)備完畢,開(kāi)始使用RecyclerView,新建一個(gè)ShowVoteAdapter.java類(lèi)。
public class ShowVoteActivity extends BaseActivity{
@BindView(R.id.vote_list_recycleview)
RecyclerView recyclerView;
private List<VoteInfo> voteInfoList=new ArrayList<VoteInfo>();
@Override
protected void onCreate(Bundle saveInstanceState) {
super.onCreate(saveInstanceState);
ScreenUtils.setContentViewWithOrientation(this,
ScreenUtils.isPhone() ? R.layout.fragment_vote_list : R.layout.fragment_vote_list);
initVoteInfo();
LinearLayoutManager linearLayoutManager=new LinearLayoutManager(this);
recyclerView.setLayoutManager(linearLayoutManager);
VoteInfoAdapter voteInfoAdapter=new VoteInfoAdapter(voteInfoList);
recyclerView.setAdapter(voteInfoAdapter);
}
private void initVoteInfo(){
VoteInfo vote1=new VoteInfo("1.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote1);
VoteInfo vote2=new VoteInfo("2.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote2);
VoteInfo vote3=new VoteInfo("3.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote3);
VoteInfo vote4=new VoteInfo("4.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote4);
VoteInfo vote5=new VoteInfo("5.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote5);
VoteInfo vote6=new VoteInfo("6.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote6);
VoteInfo vote7=new VoteInfo("7.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote7);
VoteInfo vote8=new VoteInfo("8.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote8);
VoteInfo vote9=new VoteInfo("9.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote9);
VoteInfo vote10=new VoteInfo("10.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote10);
VoteInfo vote11=new VoteInfo("11.請(qǐng)問(wèn)以下哪個(gè)答案最佳?",new String[]{"AAAAAA","BBBBBB","CCCCCC"});
voteInfoList.add(vote11);
}
}
六、需要AndroidManifest.xml中注冊(cè)ShowVoteActivity,才能夠正常啟動(dòng)。
<activity android:name="com.inpor.fastmeetingcloud.activity.ShowVoteActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:screenOrientation="portrait" android:windowSoftInputMode="stateAlwaysHidden|adjustPan" />
七、最終界面效果圖

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android 根據(jù)EditText搜索框ListView動(dòng)態(tài)顯示數(shù)據(jù)
這篇文章主要介紹了Android 根據(jù)EditText搜索框ListView動(dòng)態(tài)顯示數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2016-09-09
Android?Choreographer源碼詳細(xì)分析
Choreographer的作用主要是配合Vsync,給上層App的渲染提供一個(gè)穩(wěn)定的Message處理的時(shí)機(jī),也就是Vsync到來(lái)的時(shí)候,系統(tǒng)通過(guò)對(duì)Vsync信號(hào)周期的調(diào)整,來(lái)控制每一幀繪制操作的時(shí)機(jī)2022-08-08
Android編程實(shí)現(xiàn)簡(jiǎn)單的UDP Client實(shí)例
這篇文章主要介紹了Android編程實(shí)現(xiàn)簡(jiǎn)單的UDP Client,結(jié)合實(shí)例形式分析了Android實(shí)現(xiàn)UDP Clinet客戶端的實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-04-04
Android實(shí)現(xiàn)朋友圈點(diǎn)贊列表
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)朋友圈點(diǎn)贊列表,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11
Android學(xué)習(xí)教程之日歷庫(kù)使用(15)
這篇文章主要為大家詳細(xì)介紹了Android學(xué)習(xí)教程之日歷庫(kù)使用的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11
Android Studio OkHttpClient使用教程詳解
這篇文章主要介紹了Android Studio OkHttpClient使用教程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
android開(kāi)發(fā)教程之wifi開(kāi)發(fā)示例
這篇文章主要介紹了android開(kāi)發(fā)教程之wifi開(kāi)發(fā)示例,需要的朋友可以參考下2014-03-03

