Zurmo(十四)之ListView之Columns

53 篇文章 0 订阅
51 篇文章 0 订阅

问题描述:如下图

这里写图片描述

把一个其它模块的model(显示其中的一个或者多个字段)在其它模块的list页面的Columns里显示出来。以Contacts模块的Columns里显示Account举例。

1:在Contacts的model的中有关于Account的relations。

      'relations' => array(
             'account'             => array(static::HAS_ONE,   'Account'),
       )

2:完成步骤1,清除缓存和更新metadata就可以在页面上看到效果了(在hidden Columns那一栏的),但是移动到右边是会报错的,需要新建一个文件,在模块的文件夹内的adapter/columns下,如下图:

这里写图片描述

3:建好文件,写好代码,刷新页面,应该就可以了(这里保持疑问)?

4:这里显示的是account的名字,初步是估计在account的model中的__toString()方法里应用的是name字段?

        public function __toString()
        {
            try
            {
                if (trim($this->name) == '')
                {
                    return Zurmo::t('Core', '(Unnamed)');
                }
                return $this->name;
            }
            catch (AccessDeniedSecurityException $e)
            {
                return '';
            }
        }

5:如果是自定义的model的话,前面4步还是这样操作,还需要最后一步,在core/utils/ModelAttributeToMixedTypeUtil.php文件里,如下图:

这里写图片描述

要在这里加上你的model的名字,Zurmo是根据这个返回值去找对应的Element元素来拼接页面的,不然的话默认的是‘DropDown’。

6:如果步骤5没有做的话,会报错的,报一个没有找到对应 ‘data’ 的错。这个错误很常见。要留心!

如有不对,请指正!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Android中使用ListView来显示天气图标和温度,可以按照以下步骤进行操作: 1. 准备数据:首先需要准备一个包含天气图标和温度信息的列表数据,可以使用ArrayList或者其他数据结构来存储。 2. 创建布局:为了显示天气图标和温度,需要为ListView中的每一项创建一个布局,可以使用LinearLayout或者RelativeLayout等布局来设计每一项的布局。 3. 创建适配器:创建一个继承自BaseAdapter的适配器类,实现getView()方法来设置每一项的布局和数据。 4. 设置适配器:在Activity或者Fragment中获取ListView控件,然后设置适配器即可显示列表数据。 以下是一个简单的示例代码,实现了一个包含天气图标和温度的列表: ``` public class MyAdapter extends BaseAdapter { private Context mContext; private ArrayList<WeatherData> mData; public MyAdapter(Context context, ArrayList<WeatherData> data) { mContext = context; mData = data; } @Override public int getCount() { return mData.size(); } @Override public Object getItem(int position) { return mData.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = convertView; ViewHolder holder; if (view == null) { view = LayoutInflater.from(mContext).inflate(R.layout.list_item, parent, false); holder = new ViewHolder(); holder.imageView = view.findViewById(R.id.image_view); holder.textView = view.findViewById(R.id.text_view); view.setTag(holder); } else { holder = (ViewHolder) view.getTag(); } WeatherData weatherData = mData.get(position); holder.textView.setText(weatherData.getTemperature() + "℃"); holder.imageView.setImageResource(weatherData.getImageResId()); return view; } static class ViewHolder { ImageView imageView; TextView textView; } } public class WeatherData { private int mImageResId; private int mTemperature; public WeatherData(int imageResId, int temperature) { mImageResId = imageResId; mTemperature = temperature; } public int getImageResId() { return mImageResId; } public int getTemperature() { return mTemperature; } } // 在Activity或者Fragment中使用适配器来显示ListView ArrayList<WeatherData> data = new ArrayList<>(); data.add(new WeatherData(R.drawable.weather_sunny, 28)); data.add(new WeatherData(R.drawable.weather_cloudy, 24)); data.add(new WeatherData(R.drawable.weather_rainy, 20)); ListView listView = findViewById(R.id.list_view); MyAdapter adapter = new MyAdapter(this, data); listView.setAdapter(adapter); ``` 在上述代码中,我们定义了一个WeatherData类来存储天气图标和温度信息,然后我们创建了一个MyAdapter类来实现适配器,通过重写getView()方法设置每一项的布局和数据。最后在Activity或者Fragment中使用适配器来显示ListView

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值