如何实现带有按钮和文本的动态LinearLayout?
How to implement dynamic LinearLayout with button and text?
我尝试以编程方式在 LinearLayout 中添加元素,该布局根据特定条件包含不同的元素。但是我完全不知道该怎么做。
我想要实现的 objective 是 Quizz 应用程序的朋友列表,它显示用户获得的朋友请求,他已经拥有的朋友。 activity 还包含一个搜索栏,允许用户在他的朋友中搜索,如果在文本栏中输入的文本与他的任何朋友都不对应,它会显示具有相似用户名的用户。
我已经尝试了很多尝试将文本动态添加到 linearLayout 并且我已经搜索了可以添加到 linearLayout 而不是 TextView 中的容器,但我没有看到任何适合我目的的容器。
我在网上搜索了一下,显然有适合我目的的 listView,但我不知道如何实现它。
这是我的 XML :
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/textView2"
android:layout_width="312dp"
android:layout_height="50dp"
android:layout_marginStart="8dp"
android:layout_marginLeft="8dp"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
android:layout_marginRight="8dp"
android:gravity="center"
android:text="@string/friendList"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="@+id/friends_menu_button"
app:layout_constraintTop_toTopOf="parent" />
<EditText
android:id="@+id/friends_edit_text"
android:layout_width="275dp"
android:layout_height="38dp"
android:layout_marginTop="8dp"
android:ems="10"
android:inputType="textPersonName|text"
android:text="@string/findFriend"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView2" />
<Button
android:id="@+id/friends_menu_button"
android:layout_width="wrap_content"
android:layout_height="53dp"
android:layout_marginStart="8dp"
android:layout_marginLeft="8dp"
android:layout_marginTop="8dp"
android:text="menu"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<ScrollView
android:id="@+id/scrollView3"
android:layout_width="415dp"
android:layout_height="0dp"
android:layout_marginStart="8dp"
android:layout_marginLeft="8dp"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
android:layout_marginRight="8dp"
android:layout_marginBottom="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/friends_edit_text">
<LinearLayout
android:id="@+id/friends_Linear_Layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" />
</ScrollView>
<Button
android:id="@+id/f_search_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
android:layout_marginRight="8dp"
android:text="search"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView2" />
</android.support.constraint.ConstraintLayout>
这是我的 Activity :
package be.uclouvain.lsinf1225.groupej2a.iqtest;
import android.content.Intent;
import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.util.Log;
import java.util.ArrayList;
import java.util.List;
public class FriendsListActivity extends AppCompatActivity {
private Button menuButton;
private Button searchButton;
private DatabaseHelper myDb;
private LinearLayout friendLayout;
private User myUser;
private EditText searchbar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_friends);
myDb = DatabaseHelper.getInstance(this);
myUser = myDb.getCurrentUser();
menuButton = (Button) findViewById(R.id.friends_menu_button);
friendLayout= (LinearLayout) findViewById(R.id.friends_Linear_Layout);
searchbar = findViewById(R.id.friends_edit_text);
searchButton = findViewById(R.id.f_search_button);
//showFriends();
searchButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String search = searchbar.getText().toString();
clearFriends();
showFriends();
}
});
menuButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent MainMenuActivity = new Intent(FriendsListActivity.this, MainMenuActivity.class);
startActivity(MainMenuActivity);
}
});
}
private void showFriends(){
LinearLayout myLayout = this.friendLayout;
DatabaseHelper db = this.myDb;
User myUser = this.myUser;
String myUsername = myUser.getUsername();
String friendList[] = db.getFriends(myUsername);
int j=0;
for(String i : friendList){
Log.d("showFriends",i);
TextView temp = new TextView(this.getApplicationContext());
temp.setText(i);
temp.setId(j);
myLayout.addView(temp);
j++;
}
}
private void clearFriends(){
LinearLayout myLayout = this.friendLayout;
DatabaseHelper db = this.myDb;
myLayout.removeAllViews();
}
}
实际结果是(我知道只有文字,但我不知道如何做不同的):
我想要这样的东西:
给我解释一下它是如何工作的,如果可能的话,一些例子不需要浪费你的时间给我代码做我想要的。
您必须使用带有自定义数组的列表视图 adapter.Try 才能在 android 开发人员指南网站或 youtube 上参考这些概念的一些教程。
我发现这门关于 udacity 的免费课程的第二课包含了很好的教程,可以满足您的需要。
您需要使用多视图recyclerview。我可以从 UI 中看出您正在使用 3 种类型的视图(即已经是朋友、请求的朋友、其他)。您需要在自定义适配器中创建 3 个布局和相应的视图持有者。
- How to create RecyclerView with multiple view type?
- https://www.journaldev.com/12372/android-recyclerview-example
我尝试以编程方式在 LinearLayout 中添加元素,该布局根据特定条件包含不同的元素。但是我完全不知道该怎么做。
我想要实现的 objective 是 Quizz 应用程序的朋友列表,它显示用户获得的朋友请求,他已经拥有的朋友。 activity 还包含一个搜索栏,允许用户在他的朋友中搜索,如果在文本栏中输入的文本与他的任何朋友都不对应,它会显示具有相似用户名的用户。
我已经尝试了很多尝试将文本动态添加到 linearLayout 并且我已经搜索了可以添加到 linearLayout 而不是 TextView 中的容器,但我没有看到任何适合我目的的容器。
我在网上搜索了一下,显然有适合我目的的 listView,但我不知道如何实现它。
这是我的 XML :
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/textView2"
android:layout_width="312dp"
android:layout_height="50dp"
android:layout_marginStart="8dp"
android:layout_marginLeft="8dp"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
android:layout_marginRight="8dp"
android:gravity="center"
android:text="@string/friendList"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="@+id/friends_menu_button"
app:layout_constraintTop_toTopOf="parent" />
<EditText
android:id="@+id/friends_edit_text"
android:layout_width="275dp"
android:layout_height="38dp"
android:layout_marginTop="8dp"
android:ems="10"
android:inputType="textPersonName|text"
android:text="@string/findFriend"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView2" />
<Button
android:id="@+id/friends_menu_button"
android:layout_width="wrap_content"
android:layout_height="53dp"
android:layout_marginStart="8dp"
android:layout_marginLeft="8dp"
android:layout_marginTop="8dp"
android:text="menu"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<ScrollView
android:id="@+id/scrollView3"
android:layout_width="415dp"
android:layout_height="0dp"
android:layout_marginStart="8dp"
android:layout_marginLeft="8dp"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
android:layout_marginRight="8dp"
android:layout_marginBottom="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/friends_edit_text">
<LinearLayout
android:id="@+id/friends_Linear_Layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" />
</ScrollView>
<Button
android:id="@+id/f_search_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
android:layout_marginRight="8dp"
android:text="search"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView2" />
</android.support.constraint.ConstraintLayout>
这是我的 Activity :
package be.uclouvain.lsinf1225.groupej2a.iqtest;
import android.content.Intent;
import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.util.Log;
import java.util.ArrayList;
import java.util.List;
public class FriendsListActivity extends AppCompatActivity {
private Button menuButton;
private Button searchButton;
private DatabaseHelper myDb;
private LinearLayout friendLayout;
private User myUser;
private EditText searchbar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_friends);
myDb = DatabaseHelper.getInstance(this);
myUser = myDb.getCurrentUser();
menuButton = (Button) findViewById(R.id.friends_menu_button);
friendLayout= (LinearLayout) findViewById(R.id.friends_Linear_Layout);
searchbar = findViewById(R.id.friends_edit_text);
searchButton = findViewById(R.id.f_search_button);
//showFriends();
searchButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String search = searchbar.getText().toString();
clearFriends();
showFriends();
}
});
menuButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent MainMenuActivity = new Intent(FriendsListActivity.this, MainMenuActivity.class);
startActivity(MainMenuActivity);
}
});
}
private void showFriends(){
LinearLayout myLayout = this.friendLayout;
DatabaseHelper db = this.myDb;
User myUser = this.myUser;
String myUsername = myUser.getUsername();
String friendList[] = db.getFriends(myUsername);
int j=0;
for(String i : friendList){
Log.d("showFriends",i);
TextView temp = new TextView(this.getApplicationContext());
temp.setText(i);
temp.setId(j);
myLayout.addView(temp);
j++;
}
}
private void clearFriends(){
LinearLayout myLayout = this.friendLayout;
DatabaseHelper db = this.myDb;
myLayout.removeAllViews();
}
}
实际结果是(我知道只有文字,但我不知道如何做不同的):
我想要这样的东西:
给我解释一下它是如何工作的,如果可能的话,一些例子不需要浪费你的时间给我代码做我想要的。
您必须使用带有自定义数组的列表视图 adapter.Try 才能在 android 开发人员指南网站或 youtube 上参考这些概念的一些教程。
我发现这门关于 udacity 的免费课程的第二课包含了很好的教程,可以满足您的需要。
您需要使用多视图recyclerview。我可以从 UI 中看出您正在使用 3 种类型的视图(即已经是朋友、请求的朋友、其他)。您需要在自定义适配器中创建 3 个布局和相应的视图持有者。
- How to create RecyclerView with multiple view type?
- https://www.journaldev.com/12372/android-recyclerview-example