Android之自定义实现BaseAdapter(优化布局)
2016-09-09 10:29
363 查看
版权声明:本文为博主原创文章,未经博主允许不得转载。
MainActivity.Java
MyAdapter.java
上面的代码实现很简单,只是借助了一个ViewHolder持有类来保存每个布局中的控件ID就可以,也正如我们在上一篇普通实现BaseAdapter的第二种实现方式中所说的虽然使解析的次数降低到最少,但是每次都要findViewById,而这里的优化就刚好是针对那种方式的优化,这样一来,解析次数已经达到了最少,findViewById的次数也达到了最少,不过对于适配器来说,没有最优,只有更优,也就是说,如果以后我们在写ListView布局的的时候,每次都用这种方式去实现是非常方便,效率也不错,每写一个ListView处理不同的数据都要去自定义BaseAdapter,如果说一两个还好,要是你的项目中有20个处理不同数据的ListView,那么是不是要写20个自定义BaseAdapter呢?所以,为了方便开发,我们可以打造一个通用的BaseAdapter,关于如何打造一个通用的BaseAdapter,将在后面的学习笔记中介绍。
Android之自定义实现BaseAdapter(优化布局)
上一篇中我们介绍了自定义实现BaseAdapter的普通实现布局,然而上一章也说了普通实现的方式效率会很低,而且对系统开销也很大,所以,那样的实现是为了让初学者能知道可以这样使用,在实际项目中不可能使用那种方式的,要是你在做项目的时候使用普通布局方式,我敢保证,不过试用期你的老板就给你飞机票走人了,好了,闲话少说,本次讲解一下优化布局的实现,看完代码后,你会觉得,其实很简单。MainActivity.Java
<code class="hljs java has-numbering"><span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MainActivity</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">AppCompatActivity</span> {</span> <span class="hljs-keyword">private</span> List<Student> data; <span class="hljs-keyword">private</span> ListView mList; <span class="hljs-annotation">@Override</span> <span class="hljs-keyword">protected</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onCreate</span>(Bundle savedInstanceState) { <span class="hljs-keyword">super</span>.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mList = (ListView)findViewById(R.id.mList); data = <span class="hljs-keyword">new</span> ArrayList<>(); Student stu = <span class="hljs-keyword">null</span>; <span class="hljs-keyword">for</span>(<span class="hljs-keyword">int</span> i = <span class="hljs-number">0</span>; i < <span class="hljs-number">5</span>; i ++){ stu = <span class="hljs-keyword">new</span> Student(); stu.setName(<span class="hljs-string">"姓名"</span>+ i); stu.setSex(i % <span class="hljs-number">2</span> == <span class="hljs-number">0</span> ? <span class="hljs-string">"男"</span> : <span class="hljs-string">"女"</span>); data.add(stu); } MyAdapter adapter = <span class="hljs-keyword">new</span> MyAdapter(data); mList.setAdapter(adapter); } }</code><ul style="" class="pre-numbering"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li><li>9</li><li>10</li><li>11</li><li>12</li><li>13</li><li>14</li><li>15</li><li>16</li><li>17</li><li>18</li><li>19</li><li>20</li></ul><ul style="" class="pre-numbering"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li><li>9</li><li>10</li><li>11</li><li>12</li><li>13</li><li>14</li><li>15</li><li>16</li><li>17</li><li>18</li><li>19</li><li>20</li></ul>
MyAdapter.java
<code class="hljs java has-numbering"><span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MyAdapter</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">BaseAdapter</span> {</span> <span class="hljs-keyword">private</span> List<Student> data; <span class="hljs-keyword">public</span> <span class="hljs-title">MyAdapter</span>(List<Student> data) { <span class="hljs-keyword">this</span>.data = data; } <span class="hljs-annotation">@Override</span> <span class="hljs-keyword">public</span> <span class="hljs-keyword">int</span> <span class="hljs-title">getCount</span>() { <span class="hljs-keyword">return</span> data == <span class="hljs-keyword">null</span> ? <span class="hljs-number">0</span> : data.size(); } <span class="hljs-annotation">@Override</span> <span class="hljs-keyword">public</span> Object <span class="hljs-title">getItem</span>(<span class="hljs-keyword">int</span> position) { <span class="hljs-keyword">return</span> data.get(position); } <span class="hljs-annotation">@Override</span> <span class="hljs-keyword">public</span> <span class="hljs-keyword">long</span> <span class="hljs-title">getItemId</span>(<span class="hljs-keyword">int</span> position) { <span class="hljs-keyword">return</span> position; } <span class="hljs-javadoc">/** * *<span class="hljs-javadoctag"> @param</span> position *<span class="hljs-javadoctag"> @param</span> convertView *<span class="hljs-javadoctag"> @param</span> parent *<span class="hljs-javadoctag"> @return</span> */</span> <span class="hljs-annotation">@Override</span> <span class="hljs-keyword">public</span> View <span class="hljs-title">getView</span>(<span class="hljs-keyword">int</span> position, View convertView, ViewGroup parent) { ViewHolder holder = <span class="hljs-keyword">null</span>; <span class="hljs-keyword">if</span>(convertView == <span class="hljs-keyword">null</span>){ <span class="hljs-comment">//解析布局</span> convertView = LayoutInflater.from(parent.getContext()).inflate(R.layout.list_item,<span class="hljs-keyword">null</span>); <span class="hljs-comment">//创建ViewHolder持有类</span> holder = <span class="hljs-keyword">new</span> ViewHolder(); <span class="hljs-comment">//将每个控件的对象保存到持有类中</span> holder.tvName = (TextView)convertView.findViewById(R.id.mTv1); holder.tvSex = (TextView)convertView.findViewById(R.id.mTv2); <span class="hljs-comment">//将每个convertView对象中设置这个持有类对象</span> convertView.setTag(holder); } <span class="hljs-comment">//每次需要使用的时候都会拿到这个持有类</span> holder = (ViewHolder)convertView.getTag(); <span class="hljs-comment">//然后可以直接使用这个类中的控件,对控件进行操作,而不用重复去findViewById了</span> holder.tvName.setText(data.get(position).getName()); holder.tvSex.setText(data.get(position).getSex()); <span class="hljs-keyword">return</span> convertView; } <span class="hljs-javadoc">/** * 通过这个类来保存当前所有的控件id */</span> <span class="hljs-keyword">static</span> class ViewHolder{ TextView tvName; TextView tvSex; } }</code><ul style="" class="pre-numbering"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li><li>9</li><li>10</li><li>11</li><li>12</li><li>13</li><li>14</li><li>15</li><li>16</li><li>17</li><li>18</li><li>19</li><li>20</li><li>21</li><li>22</li><li>23</li><li>24</li><li>25</li><li>26</li><li>27</li><li>28</li><li>29</li><li>30</li><li>31</li><li>32</li><li>33</li><li>34</li><li>35</li><li>36</li><li>37</li><li>38</li><li>39</li><li>40</li><li>41</li><li>42</li><li>43</li><li>44</li><li>45</li><li>46</li><li>47</li><li>48</li><li>49</li><li>50</li><li>51</li><li>52</li><li>53</li><li>54</li><li>55</li><li>56</li><li>57</li><li>58</li><li>59</li><li>60</li></ul><ul style="" class="pre-numbering"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li><li>9</li><li>10</li><li>11</li><li>12</li><li>13</li><li>14</li><li>15</li><li>16</li><li>17</li><li>18</li><li>19</li><li>20</li><li>21</li><li>22</li><li>23</li><li>24</li><li>25</li><li>26</li><li>27</li><li>28</li><li>29</li><li>30</li><li>31</li><li>32</li><li>33</li><li>34</li><li>35</li><li>36</li><li>37</li><li>38</li><li>39</li><li>40</li><li>41</li><li>42</li><li>43</li><li>44</li><li>45</li><li>46</li><li>47</li><li>48</li><li>49</li><li>50</li><li>51</li><li>52</li><li>53</li><li>54</li><li>55</li><li>56</li><li>57</li><li>58</li><li>59</li><li>60</li></ul>
上面的代码实现很简单,只是借助了一个ViewHolder持有类来保存每个布局中的控件ID就可以,也正如我们在上一篇普通实现BaseAdapter的第二种实现方式中所说的虽然使解析的次数降低到最少,但是每次都要findViewById,而这里的优化就刚好是针对那种方式的优化,这样一来,解析次数已经达到了最少,findViewById的次数也达到了最少,不过对于适配器来说,没有最优,只有更优,也就是说,如果以后我们在写ListView布局的的时候,每次都用这种方式去实现是非常方便,效率也不错,每写一个ListView处理不同的数据都要去自定义BaseAdapter,如果说一两个还好,要是你的项目中有20个处理不同数据的ListView,那么是不是要写20个自定义BaseAdapter呢?所以,为了方便开发,我们可以打造一个通用的BaseAdapter,关于如何打造一个通用的BaseAdapter,将在后面的学习笔记中介绍。
相关文章推荐
- Android自定义实现BaseAdapter的优化布局
- Android之自定义实现BaseAdapter(优化布局)
- Android Toast优化--通过自定义布局实现界面美化
- android之自定义ViewGroup和自动换行的布局的实现
- Android自定义View设定到FrameLayout布局中实现多组件显示
- android之自定义ViewGroup和自动换行的布局的实现
- android之自定义ViewGroup和自动换行的布局的实现
- android之自定义ViewGroup和自动换行的布局的实现
- android自定义RadioGroup实现可以添加多种布局
- Android中ListView同过自定义布局并使用SimpleAdapter的方式实现数据的绑定
- android之自定义ViewGroup和自动换行的布局的实现
- Android开发中自定义View设定到FrameLayout布局中实现多组件显示
- Android Notification自定义布局实现
- android自定义RadioGroup可以添加多种布局的实现方法
- android之自定义ViewGroup和自动换行的布局的实现
- android之自定义ViewGroup和自动换行的布局的实现
- android之自定义ViewGroup和自动换行的布局的实现
- 来实现android自定义的menu菜单之二:为自定义menu中的线性布局添加事件
- android自定义viewgroup实现等分格子布局
- android自定义RadioGroup实现可以添加多种布局