【问题标题】:Android Java dynamic button clickAndroid Java 动态按钮点击
【发布时间】:2016-11-20 20:18:06
【问题描述】:

我正在根据从 JSON 对象/数组中获得的数据生成按钮。从 API 获取。 目前我有 20 个循环可以这么说(20 个数据,20 个按钮)。

按钮的 xml / 布局如下所示:

    <Button
        android:id="@+id/details"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

目前获取数据并在我的布局中打印的代码如下所示:

public class MainActivity extends AppCompatActivity
        implements NavigationView.OnNavigationItemSelectedListener {


    private String TAG = MainActivity.class.getSimpleName();

    private ProgressDialog pDialog;
    private ListView lv;

    // URL to get contacts JSON
    private static String url = "http://192.168.178.32:8888/test/public/index";
       ArrayList<HashMap<String, String>> contactList;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        contactList = new ArrayList<>();

        new GetContacts().execute();
    lv = (ListView) findViewById(R.id.list);

    FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
    fab.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                    .setAction("Action", null).show();
        }
    });

    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
            this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
    drawer.setDrawerListener(toggle);
    toggle.syncState();

    NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
    navigationView.setNavigationItemSelectedListener(this);
}

    @Override
    protected Void doInBackground(Void... arg0) {
        HttpHandler sh = new HttpHandler();

        // Making a request to url and getting response
        String jsonStr = sh.makeServiceCall(url);

        Log.e(TAG, "Response from url: " + jsonStr);

        if (jsonStr != null) {
            try {
                // Getting JSON Array node
                JSONArray jsonArray = new JSONArray(jsonStr);

                // looping through All Contacts
                for (int i = 0; i < jsonArray.length(); i++) {
                    JSONObject c = jsonArray.getJSONObject(i);

                    String id = c.getString("id");
                    String name = c.getString("name");
                    String description = c.getString("description");

                    // tmp hash map for single contact
                    HashMap<String, String> data = new HashMap<>();

                    // adding each child node to HashMap key => value
                    data.put("id", id);
                    data.put("name", name);
                    data.put("description", description);

                    // adding contact to contact list
                    contactList.add(data);
                }
            } catch (final JSONException e) {
                Log.e(TAG, "Json parsing error: " + e.getMessage());
                runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        Toast.makeText(getApplicationContext(),
                                "Json parsing error: " + e.getMessage(),
                                Toast.LENGTH_LONG)
                                .show();
                    }
                });

            }
        } else {
            Log.e(TAG, "Couldn't get json from server.");
            runOnUiThread(new Runnable() {
                @Override
                public void run() {
                    Toast.makeText(getApplicationContext(),
                            "Couldn't get json from server. Check LogCat for possible errors!",
                            Toast.LENGTH_LONG)
                            .show();
                }
            });

        }

        return null;
    }

    @Override
    protected void onPostExecute(Void result) {
        super.onPostExecute(result);
        // Dismiss the progress dialog
        if (pDialog.isShowing())
            pDialog.dismiss();
        /**
         * Updating parsed JSON data into ListView
         * */
        ListAdapter adapter = new SimpleAdapter(
                MainActivity.this, contactList,
                R.layout.list_item, new String[]{"name", "description"}, new int[]{R.id.name,
                R.id.description, R.id.release_at});

        lv.setAdapter(adapter);
    }

我的适配器看起来像这样:

public class RecyclerAdapter extends RecyclerView.Adapter<RecyclerAdapter.ViewHolder> {

    private List<String> friends;
    private Activity activity;

    public RecyclerAdapter(Activity activity, List<String> friends, ArrayList<HashMap<String, String>> contactList) {
        this.friends = friends;
        this.activity = activity;
    }

    @Override
    public ViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) {

        //inflate your layout and pass it to view holder
        LayoutInflater inflater = activity.getLayoutInflater();
        View view = inflater.inflate(android.R.layout.simple_list_item_1, viewGroup, false);
        ViewHolder viewHolder = new ViewHolder(view);

        return viewHolder;
    }

    @Override
    public void onBindViewHolder(RecyclerAdapter.ViewHolder viewHolder, int position) {

        viewHolder.item.setText(friends.get(position));
    }

    @Override
    public int getItemCount() {
        return (null != friends ? friends.size() : 0);
    }

    /**
     * View holder to display each RecylerView item
     */
    protected class ViewHolder extends RecyclerView.ViewHolder {
        private TextView item;

        public ViewHolder(View view) {
            super(view);
            item = (TextView) view.findViewById(android.R.id.text1);
        }
    }

}

我的想法是点击每个按钮并在另一个活动中更详细地显示相关数据。

但是我怎样才能通过循环运行并获得正确的按钮 (id) 并使用其相关数据创建一个新的 Activity。

【问题讨论】:

    标签: java android json xml adapter


    【解决方案1】:

    在适配器的 getView 方法中,您可以为该行中的按钮设置一个 onClickLister,该按钮将引用该行的数据。使用 Intent 启动详细的 Activity 并将点击项的数据添加为额外数据。

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
    
        //Inflate your row
    
        button.setOnClickListener(new OnClickListener(){
            @Override
            //On click function
            public void onClick(View view) {
                 HashMap<String, String> item = contactsList.get(position);
                 //Create the intent to start another activity
                 Intent intent = new Intent(view.getContext(), DetailActivity.class);
                 intent.putExtra("data", item);
                 view.getContext().startActivity(intent);
            }
        });
    });
    

    在接收activity中,可以从intent中获取数据:

    HashMap<String, String> data = getIntent().getExtras().getParcelableExtra("data");
    

    【讨论】:

    • 因此我如何从我的 MainActivity 中获取 contactsList 到我的 Recycler Adpater 中(对不起,我在 android 方面没有经验)
    • 我目前得到的错误是OnClickListener contactsList.get(position).getParcelableExtra("data"),如果你介意我们也可以把它移到聊天中
    【解决方案2】:

    扩展ArrayAdapter 并将构造函数参数中的联系人列表传递给它。将该列表分配给ArrayAdapter 内的字段,然后在您的getView() 方法中,您可以通过简单的list.get(position) 获取您的项目。

    【讨论】:

    • 你能贴出我必须如何更改它的代码吗,我在android开发方面没有那么经验
    • @utdev see here
    • 在这种情况下,ArrayAdapter 会与我的 RecyclerAdapter 相似吗?
    • @utdev 您在代码中使用了ListView。但是,是的,如果您使用的是RecyclerView,它是一样的。只需将您的列表传递给构造函数或在您的 RecyclerView.Adapter 中使用 setter
    • 上面的代码是我的 MainActivity,我很困惑抱歉我应该在哪里传递我的 Listview 来构造?
    猜你喜欢
    • 2013-08-22
    • 2014-03-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多