0

次のチュートリアルhttp://www.ezzylearning.com/tutorial.aspx?tid=1763429を使用して、カスタマイズされた listView を作成しました。

リスト ビューには 2 つの行が含まれています (それぞれに画像と TextView があります)。最初の行はユーザー、2 番目の行はパスワードです。パスワード行を **** のようにマスクして、ユーザーが表示/マスクに設定できるようにする別の行を追加する方法を探しています。

次の例を見つけました 。テキストビューで非表示のパスワードを表示するには? パスワードの非表示と表示を切り替える方法

しかし、これを特定の行に実装する方法がわかりません。

私の行xml

    <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="horizontal" >

     <ImageView android:id="@+id/imgUserAccountIcon"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:layout_marginRight="10dp"
        android:layout_marginTop="5dp"
        android:gravity="center_vertical"
        android:scaleType="fitStart" />

     <TextView android:id="@+id/txtTitle"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="10dp" 
                    android:layout_marginTop="5dp"
            />


</LinearLayout>

私のユーザークラス

public class UserAccountData {
    public int icon;
    public String title;

    public UserAccountData(){
        super();
    }


public UserAccountData(int icon, String title) {
    super();
    this.icon = icon;
        this.title = title;
    }
}

私のアダプタークラス

public class UserAccountAdapter extends ArrayAdapter<UserAccountData> {
    Context context;
    int layoutResourceId;
    UserAccountData data[] = null;
public UserAccountAdapter(Context context, int layoutResourceId,
        UserAccountData[] data) {
    super(context, layoutResourceId, data);
    this.layoutResourceId = layoutResourceId;
    this.context = context;
    this.data = data;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    View row = convertView;
    UserAccountDataHolder holder = null;

    if (row == null) {
        LayoutInflater inflater = ((Activity) context).getLayoutInflater();
        row = inflater.inflate(layoutResourceId, parent, false);

        holder = new UserAccountDataHolder();
        holder.imgIcon = (ImageView) row.findViewById(R.id.imgUserAccountIcon);
        holder.txtTitle = (TextView) row.findViewById(R.id.txtTitle);

        row.setTag(holder);
    } else {
        holder = (UserAccountDataHolder) row.getTag();
    }

    UserAccountData userAccountData = data[position];
    holder.txtTitle.setText(userAccountData.title);     
    holder.imgIcon.setImageResource(userAccountData.icon);


    return row;
}

static class UserAccountDataHolder {
    ImageView imgIcon;
    TextView txtTitle;
}

}

およびアクティビティ メソッドの適切なリスト ビュー スニペット

List<UserAccountData> user_data = new ArrayList<UserAccountData>();
user_data.add(new UserAccountData(R.drawable.username_icon,"userName");
user_data.add(new UserAccountData(R.drawable.password_icon,"password");
usersArray = new UserAccountData[user_data.size()];
user_data.toArray(usersArray);

UserAccountAdapter adapter = new UserAccountAdapter(this,                       R.layout.user_accounts_row, usersArray);

userAccountsListView = (ListView) findViewById(R.id.userAccounts);

   userAccountsListView.setAdapter(adapter);

やりたいことの写真を添付する

クリック前:

ここに画像の説明を入力

クリック後

ここに画像の説明を入力

ありがとう

4

3 に答える 3

0

セットがある場合、このような少数の行は、ListViewよりもTableLayoutの方が適しています。次に、2つのTextViewのxmlを簡単にカスタマイズできます。もう1つのオプションは、setRawInputTypeを呼び出して、2番目のTextViewだけにパスワードを設定することです。ビューの位置に基づいて、アダプタのgetView関数でこれを行う必要があります。

于 2013-01-25T21:44:56.230 に答える
0

膨らませている間に、アダプターの TextViews のリストを埋めることができます。インフレーション後、すべての TextView にアクセスできるようになり、onItemClickListener で、誰かが位置 2 のアイテムをクリックしたときに (この場合は少なくとも)、TextView のリストを参照して適切なリストを取得し、その場でパラメータを変更します。

于 2013-01-25T21:42:49.470 に答える
0

ユーザーが ListView エントリをクリックしたときに、AlertDialog にパスワードをプレーンテキストとして表示することで、この問題を回避しました。

于 2014-01-06T15:34:25.770 に答える