在适配器中获取android上下文

时间:2012-08-27 07:15:34

标签: android android-adapter android-context

在我在互联网上找到的许多代码示例中,context是在适配器的构造函数中获得的。

此上下文用于让inflatergetView方法中使视图膨胀。

我的问题是为什么在构造函数中获取上下文时可以轻松获取上下文的原因

        LayoutInflater inflater;
        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            if(inflater == null){
            Context context = parent.getContext();
            inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            }
            ...
            ...

            return convertView;
        }

也有任何理由不使用上述方法,因为直到现在我还没有遇到任何使用它的问题。

5 个答案:

答案 0 :(得分:33)

在构造函数中获取Context有(至少)三个优点:

  1. 您只需执行一次,而不是每次都调用getView()
  2. 您也可以在需要时将其用于其他目的。
  3. parentnull时,它也有效。
  4. 但是,如果您的解决方案没有任何问题,您可以坚持下去。

答案 1 :(得分:2)

如果某人创建了一个使用BaseAdapter在某处存储视图的类(并且可能会稍后将它们附加到父级),该怎么办?在这种情况下,parent可能是null

这不是一个大问题,自己决定什么是更好的。

例如:

public class MockWithAdapter{

    private BaseAdapter mAdapter;

    public MockWithAdapter(BaseAdapter adapter){
        mAdapter = adapter;
    }

    public List<View> mock(){
        int size = mAdapter.getCount();
        List<View> views = new ArrayList(size);
        for(int i=0; i<size; i++)
            views.add(mAdapter.getView(i, null, null));

        return views;
    }
}

然后你可以随意使用这些视图:

MockWithAdapter m = new MockWithAdapter(adapter);
ListView lv = new ListView(context);
for(View v : m.mock)
    lv.addView(v);

答案 2 :(得分:2)

以下是一个例子:

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    View view = convertView;
    Holder holder;
    if (view == null) {
        view = LayoutInflater.from(parent.getContext())
                .inflate(R.layout.item_job, parent, false);
        holder = new Holder(view, this);
        view.setTag(holder);
    } else {
        holder = (Holder) view.getTag();
    }

    holder.parse(getItem(position), position);
    return view;
}

public class Holder {

    @Bind(R.id.type)
    TextView type;
    @Bind(R.id.date_time)
    TextView dateTime;
    @Bind(R.id.grade)
    TextView grade;

    public Holder(View view) {
        ButterKnife.bind(this, view);
    }

    public void parse(final GetGradeHistoryResponse.GradeHistory item) {
        if (item.grade < 0) {
            grade.setTextColor(App.getInstance()
                    .getResources().getColor(R.color.withdraw_status));
            grade.setText(String.valueOf(item.grade));
        } else {
            grade.setTextColor(App.getInstance()
                    .getResources().getColor(R.color.primary));
            grade.setText("+" + String.valueOf(item.grade));
        }

        type.setText(item.type);
        dateTime.setText(item.datetime);
    }
}

您可以按view.getContext() in the Holder

获取上下文

答案 3 :(得分:0)

就这么简单!

class RecentlyAdapter(var data: List<String>) : Adapter<RecentlyAdapter.HomeViewHolder>() {

override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): HomeViewHolder {
    val inflater = LayoutInflater.from(parent.context)
    val view = inflater.inflate(R.layout.card_recently_played, parent, false)
    return HomeViewHolder(view)
}

override fun getItemCount(): Int {
    return data.size
}

override fun onBindViewHolder(holder: HomeViewHolder, position: Int) {

}

class HomeViewHolder(itemView: View): ViewHolder(itemView) {
    init {
        itemView.setOnClickListener {
            val intent = Intent(itemView.context, MusicPlayerActivity::class.java)
            itemView.context.startActivity(intent)
        }
    }
}

}

要获取上下文,请使用itemView.context

答案 4 :(得分:0)

是的,但是如果您需要任何活动引用(例如对话框警报),则不能使用上下文引用,因此构造函数应通过调用Activity / Fragment来接收活动引用