在Android中使用Switch框的Titanium视图导致滚动时出现问题?

时间:2011-09-07 10:17:23

标签: android titanium

我创建表视图,每行都包含Text和复选框,用数据库中的值加载行,其中我设置了一些默认值为true的复选框,其余为false,但是当我滚动复选框时默认选中我设置的位置它是假的,而只滚动问题发生,我不知道如何解决。

这是我使用的代码。

我也试过而不是设置复选框的默认值,我将所有复选框初始化为false,同时在运行时选中任何复选框并向下滚动其他一些文本框也是选中的,它只在滚动时发生,我不会知道如何解决这个问题,如果有人知道意味着帮助我。

function setArray(){                
            var db = Ti.Database.install('../databases/ChecklistDB.sqlite','ChecklistDB');
            var rows = db.execute('SELECT DISTINCT category, defaultCheck FROM revcheck ORDER BY id');              
            var dataArray = [];         
            while (rows.isValidRow())
            {                   
                var bgcolor = 'black';
                var fontColor = 'white';                                    
                dataArray.push({
                    title: rows.fieldByName('category'),
                    check: rows.fieldByName('defaultCheck'),
                hasChild:true,           
                backgroundColor:bgcolor,
                color:fontColor,                    
                font:{fontSize:'12dp',fontFamily:'Helvetica Neue',fontWeight:'bold'}, 
                path:'../scripts/Contents.js'

                });
                rows.next();    
            }
            dataItems = [];
            //var checkbox=[];              
                for (var i =0; i < dataArray.length; i++) {
                var row = Titanium.UI.createTableViewRow();             
                var lblTitle = Titanium.UI.createLabel({
                text:dataArray[i].title,
                left:40                     
                });

                    var checkbox= Titanium.UI.createSwitch({
                    style:Titanium.UI.Android.SWITCH_STYLE_CHECKBOX,    
                    ret:dataArray[i].title,
                    left:0
                        }); 


                    if(checkbox.ret=='Metadata'){
                         checkbox.value = true;
                    }           
                     else{
                        checkbox.value = false;
                     }
                var button = Titanium.UI.createButton({
                image:'../images/arrows.png',
                left:270                    
                }); 
                button.addEventListener('click', function(){
                var win = Titanium.UI.createWindow({
                url:'../scripts/Contents.js',               
                fullscreen: false
                }); 
                    win.open();
                });


                row.add(lblTitle);
                row.add(checkbox);
                row.label = lblTitle;                   
                //row.checkbox = checkbox;
                row.add(button);
                row.button = button;
                row.className = 'ContentsRow';
                dataItems.push(row);


                }   
            tableview.setData(dataItems);


        }

        var tableview = Ti.UI.createTableView({
            backgroundColor:'black',
            backgroundSelectedColor:'#12A1FF',                  
            top:'2%',
            left:0,
            height:'95%',
            width:'100%'                
        }); 

        setArray();

感谢。 enter image description here enter image description here

1 个答案:

答案 0 :(得分:3)

尝试在表上设置className属性。你还在使用什么版本的SDK。