ListView item 禁止RatingBar选择或改变

22 篇文章 0 订阅
6 篇文章 0 订阅

直接添加属性就解决问题了。

android:isIndicator="true"


下面的就是自己觉得值得记下的内容,想看就看吧。

我的RatingBar:

                   <RatingBar
                        android:id="@+id/ratingBar1"
                        style="@style/myRatingBar"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:isIndicator="true"
                        android:numStars="5"
                        android:rating="2.5"
                        android:stepSize="0" />

由于系统样式比较难看,我用的是自定义样式,自己选择星星图片下面是方法。

ratingbar_bg.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <!-- 表示设置的背景 -->
    <item
        android:id="@+android:id/background"
        android:drawable="@drawable/star_empty"/>
    <!-- 表示点击评分的时候的图片 -->
    <item
        android:id="@+android:id/progress"
        android:drawable="@drawable/star_full"/>
   <!--  <item
        android:id="@+android:id/background"
        android:drawable="@drawable/star_full"/> -->
</layer-list>
在style.xml里添加下面样式。
    <style name="myRatingBar" parent="@android:style/Widget.RatingBar">
        <item name="android:progressDrawable">@drawable/ratingbar_bg</item>
        <item name="android:minWidth">53dip</item>
        <item name="android:maxHeight">53dip</item>
    </style>

下面是效果图:


这是是我用到的星星图标地址,各种个大小的 都有:http://www.easyicon.net/1132071-star_icon.html,不喜欢的话就在网站搜一下star很多的。


另外:

ListView默认情况

当item有焦点时,item上的button等子控件无法获取焦点,当子控件有焦点时,item无法获取焦点响应事件。

ViewGroup.FOCUS_AFTER_DESCENDANTS:表示item的子控件优先于item获得焦点;

ViewGroup.FOCUS_BEFORE_DESCENDANTS:表示item优先于其子控件获得焦点。

  public void onItemSelected(AdapterView<?> parent, View view,  
            int position, long id) {  
        //使选中的item的子控件需要获得焦点
        parent.setDescendantFocusability(ViewGroup.FOCUS_BEFORE_DESCENDANTS);  
        //使选中的item获得焦点parent.setDescendantFocusability(ViewGroup.FOCUS_BEFORE_DESCENDANTS);  
   }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值