Titanium: Ошибка при попытке воспроизвести звук при нажатии строки в таблице? - PullRequest
0 голосов
/ 09 апреля 2011

Я делаю довольно простое приложение, которое отображает таблицу, в которой каждая строка содержит английское слово и соответствующее польское слово. Когда строка нажата, она должна воспроизвести звуковой клип с выраженным словом. Тем не менее, я не могу заставить его работать, даже несмотря на то, что я пытался устранить его со всем, что может предложить Google. Был бы признателен, если бы кто-то мог указать на недостаток ...

var win = Titanium.UI.currentWindow;
var data =[];

var CustomData = [
{ file:'001', english:'Do you?', polish:'Czy masz?', fav:false },
{ file:'002', english:'How long?', polish:'Jak d?ugo?', fav:false },
{ file:'003', english:'Is it?', polish:'Czy?', fav:false },
];

var section = Ti.UI.createTableViewSection();
data.push(section);

for (var i=0; i<CustomData.length; i++) {
    var row = Ti.UI.createTableViewRow({layout : 'vertical', height:'auto'});

    var item = Ti.UI.createLabel({
        color:'#000',
        text:CustomData[i].english,
        font:{fontSize:12, fontWeight:'bold'},
        top:3,
        left:10,
            right:30,
        height:'auto'
    });
    row.add(item);

    var cost = Ti.UI.createLabel({
        color:'#444',
        text:CustomData[i].polish,
        font:{fontSize:12},
        top:0,
        left:15,
        right:30,
        bottom:5,
        height:'auto'
    });

    row.add(cost);
    row.filter = CustomData[i].english; 
    section.add(row);
};

var tableview = Titanium.UI.createTableView({
    data:data, search:search, searchHidden:false, filterAttribute: 'filter' });

win.add(tableview);

tableview.addEventListener('click', function(e)
{
    var sound = Titanium.Media.createSound();
    sound.url = '../sound/' + e.rowData.file + '.mp3';
    sound.play();

    if (e.rowData.test)
    {
            var win = Titanium.UI.createWindow({
                    url:e.rowData.test,
                    title:e.rowData.title
            });
            Titanium.UI.currentTab.open(win,{animated:true});
    }
});

1 Ответ

0 голосов
/ 09 апреля 2011

Просто выстрел в темноте, но вы уверены, что можете установить URL после создания звукового объекта?Вы пробовали:

Titanium.Media.createSound({url:'../sound/' + e.rowData.file + '.mp3'});

Помимо этого, вы уверены, что относительный URL-адрес оценивается с того места, где вы думаете?Может быть, попробуйте это с абсолютным URL, просто чтобы быть уверенным.

...