С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

Программирование Android

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.67
Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,189
Записей в блоге: 5
#1

XmlPullParser неправильно получает значения - Программирование Android

16.07.2013, 11:02. Просмотров 1663. Ответов 21
Метки нет (Все метки)

Здравствуйте. Пытаюсь написать обработку XML сообщения от сервера, получить правильно данные (ссылку на изображение и имя), загрузить изображение в ImageView и имя в TextView, все это создаваться будет динамически.
Все работает если отдельно получать имя и ссылку на картинку, а вот если вместе, то возник косяк, приложение вылетает после запуска, вот такое XML сообщение:
XML
1
2
3
4
5
6
7
8
<item>
    <lnk>http://home-android.ru/content/games/290/1362551973778339B.jpg</lnk>
    <name>Subway Surfers</name>
</item>
<item>
    <lnk>http://home-android.ru/content/games/903/13694796854695B.png</lnk>
    <name>Ultimate Stick Fight</name>
</item>
И вот то что я накодил:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
package com.t.test; 
 
import java.io.IOException; 
import java.io.InputStream; 
import java.net.URL; 
 
import org.xmlpull.v1.XmlPullParser; 
import org.xmlpull.v1.XmlPullParserException; 
import org.xmlpull.v1.XmlPullParserFactory; 
 
import android.os.AsyncTask; 
import android.os.Bundle; 
import android.app.Activity; 
import android.content.res.XmlResourceParser; 
import android.graphics.Bitmap; 
import android.graphics.BitmapFactory; 
import android.util.Log; 
import android.widget.ImageView; 
import android.widget.LinearLayout;
import android.widget.TextView; 
 
public class Main extends Activity { 
 
    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
        super.onCreate(savedInstanceState); 
        setContentView(R.layout.main); 
 
         
        AsyncDownloader downloader = new AsyncDownloader(); 
        downloader.execute();  
    }  
     
    public void rec(String lnk, String name) 
    { 
         LinearLayout layout = (LinearLayout) findViewById(R.id.lin1);
         
         TextView txt = new TextView(this); 
         txt.setText(name); 
         layout.addView(txt);
         
         ImageView image = new ImageView(this);
         layout.addView(image);
         new DownloadImageTask(image).execute(lnk);
    } 
     
     
    class AsyncDownloader extends AsyncTask<Object, String, Integer>{ 
 
        @Override 
        protected Integer doInBackground(Object... params) { 
             
            XmlPullParser recivedData = null; 
            try { 
                recivedData = tryDownloadingXmlData(); 
            } catch (IOException e) { 
                // TODO Auto-generated catch block 
                e.printStackTrace(); 
            } 
            int recordsFound = 0; 
            try { 
                recordsFound = tryParsingXmlData(recivedData); 
            } catch (XmlPullParserException e) { 
                // TODO Auto-generated catch block 
                e.printStackTrace(); 
            } catch (IOException e) { 
                // TODO Auto-generated catch block 
                e.printStackTrace(); 
            } 
            return recordsFound; 
        } 
         
        private XmlPullParser tryDownloadingXmlData() throws IOException {     
            try{ 
            URL xmlUrl = new URL("http://home-android.ru/android/main"); 
            XmlPullParser recivedData = XmlPullParserFactory.newInstance().newPullParser(); 
            recivedData.setInput(xmlUrl.openStream(),null); 
            return recivedData; 
            }  
            catch(XmlPullParserException e){ } 
            catch(IOException e) { } 
            return null; 
        } 
         
         
        private int tryParsingXmlData(XmlPullParser recivedData) throws XmlPullParserException, IOException { 
            if(recivedData != null) 
            { 
                processRecivedData(recivedData); 
            } 
            return 0; 
        } 
 
 
 
        private void processRecivedData(XmlPullParser xmlData) throws XmlPullParserException, IOException { 
            int eventType = -1; 
            int recordsFound = 0; 
             
            String lnk=""; 
            String name=""; 
             
             
            while(eventType!=XmlResourceParser.END_DOCUMENT) 
            { 
                String tagName=xmlData.getName(); 
                switch(eventType) 
                { 
                case XmlResourceParser.START_TAG: 
                    if(xmlData.getText()!=null && tagName.equals("item")) 
                    { 
                        continue;
                    } 
                break; 
                 
                case XmlResourceParser.TEXT: 
                    if (tagName.equals("lnk")) {
                    lnk=xmlData.getText(); 
                    }
                    if (tagName.equals("name")) {
                        name = xmlData.getText();
                    }
                break; 
                 
                 
                case XmlResourceParser.END_TAG: 
                    if(tagName.equals("item")) 
                    { 
                        recordsFound++; 
                        publishProgress(lnk,name); 
                    } 
                break; 
                } 
                eventType=xmlData.next(); 
                 
                if(recordsFound==0){ 
                    publishProgress(); 
                } 
            } 
             
             
             
        } 
 
         
        @Override 
        protected void onPostExecute(Integer result) { 
            super.onPostExecute(result); 
            //  код 
        } 
         
 
 
        @Override 
        protected void onProgressUpdate(String... values){ 
             
            if(values.length>1) 
            { 
                String lnk = values[0]; 
                String name = values[1];
                 
                    Main.this.rec(lnk,name); 
                 
            }
             
            super.onProgressUpdate(values); 
        } 
         
         
    }     
    
    
    
    
    
     
    class DownloadImageTask extends AsyncTask<String, Void, Bitmap> { 
        ImageView bmImage; 
 
        DownloadImageTask(ImageView bmImage) { 
            this.bmImage = bmImage; 
        } 
 
        protected Bitmap doInBackground(String... urls) { 
            String urldisplay = urls[0]; 
            Bitmap mIcon11 = null; 
            try { 
                InputStream in = new java.net.URL(urldisplay).openStream(); 
                mIcon11 = BitmapFactory.decodeStream(in); 
            } catch (Exception e) { 
                Log.e("Error", e.getMessage()); 
                e.printStackTrace(); 
            } 
            return mIcon11; 
        } 
 
        protected void onPostExecute(Bitmap result) { 
            bmImage.setImageBitmap(result); 
        } 
    } 
     
         
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.07.2013, 11:02
Здравствуйте! Я подобрал для вас темы с ответами на вопрос XmlPullParser неправильно получает значения (Программирование Android):

Медленный XmlPullParser - Программирование Android
Всем привет! Собственно проблема всего лишь в скорости работы, по логам посмотрел что медленно грузит так это именно: ...

Самозакрывающийся тег XmlPullParser - Программирование Android
Здравствуйте уважаемые форумчане! Возникла проблемка: не могу спарсить самозакрывающийся тег: &lt;string/&gt; Когда парсер нактнется на...

RSS reader by XmlPullParser + Listview - Программирование Android
Написал программу для чтения RSS: https://github.com/PhantomRec/RSS Всё работает, но проблема в том, что показывает 5-7 тем, далее...

XmlPullParser - проверка существования атрибута - Программирование Android
Добрый день. Возникла необходимость проверять наличие в xml файле какого-либо атрибута. Подскажите метод, если таковой есть. В гугле и...

XMLPullParser чтение русских символов - Программирование Android
Здравствуйте. Согласно заданию, необходимо написать парсер, который будет эммм... парсить(масло масленое) вот эту вот страницу...

Переменная не получает отрицательное значение - Программирование Android
Всем привет! Если эта тема уже была то извиняюсь, просто даже не знаю как её прогуглить гуглить Имеется код Random randproc =...

21
V0v1k
1159 / 983 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:14 #16
ну вот же
tagName = null
NullPointerException
1
Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,189
Записей в блоге: 5
17.07.2013, 00:23  [ТС] #17
Цитата Сообщение от V0v1k Посмотреть сообщение
ну вот же
сделал так:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
 switch(eventType)  
                { 
                    case XmlResourceParser.START_TAG: 
                    Log.d(TAG, "START_TAG: name = " + xmlData.getName());     
                    break; 
                 
 
                  // содержимое тэга
                case XmlResourceParser.TEXT:
                     
                      Log.d(TAG, "text = " + xmlData.getText());
                      if (tagName!=null) {
                          if(tagName.equals("name")) {
                              name = xmlData.getText();
                          }
                          if(tagName.equals("lnk")) {
                              lnk = xmlData.getText();
                          }
                      }
                     
                     
                    break;
 
                  case XmlResourceParser.END_TAG:
                      Log.d(TAG, "END_TAG: name = " + xmlData.getName());
                      recordsFound++; 
                     //publishProgress(lnk,name); 
                      Log.d(TAG, "publishProgress: name = " +name+ "; lnk = " + lnk);
                      break;
                
                
 
                  default:  break;
                    
 
                }
В publishProgress() почемуто ничего не попадает:

Код
07-16 19:14:14.298: E/Trace(8018): error opening trace file: No such file or directory (2)
07-16 19:14:14.799: D/MyLog(8018): strat app TEST
07-16 19:14:14.799: D/MyLog(8018): AsyncDownloader
07-16 19:14:14.858: D/MyLog(8018): Execute AD
07-16 19:14:14.978: D/gralloc_goldfish(8018): Emulator without GPU emulation detected.
07-16 19:14:15.288: I/Choreographer(8018): Skipped 34 frames!  The application may be doing too much work on its main thread.
07-16 19:14:15.789: D/MyLog(8018): XML получен
07-16 19:14:15.789: D/MyLog(8018): Старт парсинга XML
07-16 19:14:15.798: D/MyLog(8018): START_TAG: name = message
07-16 19:14:15.798: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.798: D/MyLog(8018): text = 
07-16 19:14:15.798: D/MyLog(8018): 				  	
07-16 19:14:15.798: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.808: D/MyLog(8018): text = http://home-android.ru/content/games/938/1369944224185203B.png
07-16 19:14:15.808: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.808: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.808: D/MyLog(8018): text = 
07-16 19:14:15.808: D/MyLog(8018): 				  	
07-16 19:14:15.808: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.808: D/MyLog(8018): text = After Earth
07-16 19:14:15.808: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.808: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.808: D/MyLog(8018): text = 
07-16 19:14:15.808: D/MyLog(8018): 				  
07-16 19:14:15.808: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.808: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.808: D/MyLog(8018): text = 
07-16 19:14:15.808: D/MyLog(8018): 			
07-16 19:14:15.818: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.818: D/MyLog(8018): text = 
07-16 19:14:15.818: D/MyLog(8018): 				  	
07-16 19:14:15.818: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.818: D/MyLog(8018): text = http://home-android.ru/content/games/870/1369196615177530B.png
07-16 19:14:15.818: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.818: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.818: D/MyLog(8018): text = 
07-16 19:14:15.818: D/MyLog(8018): 				  	
07-16 19:14:15.818: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.818: D/MyLog(8018): text = Dig!
07-16 19:14:15.818: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.828: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.828: D/MyLog(8018): text = 
07-16 19:14:15.828: D/MyLog(8018): 				  
07-16 19:14:15.828: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.828: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.828: D/MyLog(8018): text = 
07-16 19:14:15.828: D/MyLog(8018): 			
07-16 19:14:15.828: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.828: D/MyLog(8018): text = 
07-16 19:14:15.828: D/MyLog(8018): 				  	
07-16 19:14:15.828: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.828: D/MyLog(8018): text = http://home-android.ru/content/games/265/1362553616267719B.jpg
07-16 19:14:15.828: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.828: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.828: D/MyLog(8018): text = 
07-16 19:14:15.828: D/MyLog(8018): 				  	
07-16 19:14:15.828: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.828: D/MyLog(8018): text = N.O.V.A. 3 - Near Orbit
07-16 19:14:15.828: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.828: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.828: D/MyLog(8018): text = 
07-16 19:14:15.828: D/MyLog(8018): 				  
07-16 19:14:15.828: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.828: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.828: D/MyLog(8018): text = 
07-16 19:14:15.828: D/MyLog(8018): 			
07-16 19:14:15.828: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.858: D/MyLog(8018): text = 
07-16 19:14:15.858: D/MyLog(8018): 				  	
07-16 19:14:15.868: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.868: D/MyLog(8018): text = http://home-android.ru/content/games/87/1363966590288068B.jpg
07-16 19:14:15.878: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.878: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.888: D/MyLog(8018): text = 
07-16 19:14:15.888: D/MyLog(8018): 				  	
07-16 19:14:15.888: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.898: D/MyLog(8018): text = Angry Birds Space Premium
07-16 19:14:15.898: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.908: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.918: D/MyLog(8018): text = 
07-16 19:14:15.918: D/MyLog(8018): 				  
07-16 19:14:15.918: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.918: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.928: D/MyLog(8018): text = 
07-16 19:14:15.928: D/MyLog(8018): 			
07-16 19:14:15.928: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.948: D/MyLog(8018): text = 
07-16 19:14:15.948: D/MyLog(8018): 				  	
07-16 19:14:15.948: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.948: D/MyLog(8018): text = http://home-android.ru/content/games/867/1369194950519074B.png
07-16 19:14:15.948: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.948: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.948: D/MyLog(8018): text = 
07-16 19:14:15.948: D/MyLog(8018): 				  	
07-16 19:14:15.948: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.948: D/MyLog(8018): text = Can Knockdown 3
07-16 19:14:15.948: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.948: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.948: D/MyLog(8018): text = 
07-16 19:14:15.948: D/MyLog(8018): 				  
07-16 19:14:15.948: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.948: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.948: D/MyLog(8018): text = 
07-16 19:14:15.948: D/MyLog(8018): 			
07-16 19:14:15.948: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.948: D/MyLog(8018): text = 
07-16 19:14:15.948: D/MyLog(8018): 				  	
07-16 19:14:15.959: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.959: D/MyLog(8018): text = http://home-android.ru/content/games/866/1369153903737515B.png
07-16 19:14:15.959: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.959: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.959: D/MyLog(8018): text = 
07-16 19:14:15.959: D/MyLog(8018): 				  	
07-16 19:14:15.959: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.959: D/MyLog(8018): text = Official Speedway GP 2013
07-16 19:14:15.959: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.959: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.959: D/MyLog(8018): text = 
07-16 19:14:15.959: D/MyLog(8018): 				  
07-16 19:14:15.959: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.959: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.959: D/MyLog(8018): text = 
07-16 19:14:15.959: D/MyLog(8018): 			
07-16 19:14:15.959: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.959: D/MyLog(8018): text = 
07-16 19:14:15.959: D/MyLog(8018): 				  	
07-16 19:14:15.959: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.968: D/MyLog(8018): text = http://home-android.ru/content/games/908/1369554954744788B.png
07-16 19:14:15.968: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.968: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.968: D/MyLog(8018): text = 
07-16 19:14:15.968: D/MyLog(8018): 				  	
07-16 19:14:15.968: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.968: D/MyLog(8018): text = World of Cubes
07-16 19:14:15.968: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.968: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.968: D/MyLog(8018): text = 
07-16 19:14:15.968: D/MyLog(8018): 				  
07-16 19:14:15.968: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.968: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.968: D/MyLog(8018): text = 
07-16 19:14:15.968: D/MyLog(8018): 			
07-16 19:14:15.968: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.968: D/MyLog(8018): text = 
07-16 19:14:15.968: D/MyLog(8018): 				  	
07-16 19:14:15.968: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.968: D/MyLog(8018): text = http://home-android.ru/content/games/199/1362633958796358B.jpg
07-16 19:14:15.968: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.968: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.968: D/MyLog(8018): text = 
07-16 19:14:15.968: D/MyLog(8018): 				  	
07-16 19:14:15.968: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.968: D/MyLog(8018): text = GTA 3 - Grand Theft Auto
07-16 19:14:15.978: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.978: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.978: D/MyLog(8018): text = 
07-16 19:14:15.978: D/MyLog(8018): 				  
07-16 19:14:15.978: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.978: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.978: D/MyLog(8018): text = 
07-16 19:14:15.978: D/MyLog(8018): 			
07-16 19:14:15.978: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.978: D/MyLog(8018): text = 
07-16 19:14:15.978: D/MyLog(8018): 				  	
07-16 19:14:15.978: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.978: D/MyLog(8018): text = http://home-android.ru/content/games/558/1362328221333110B.jpg
07-16 19:14:15.978: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.978: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.978: D/MyLog(8018): text = 
07-16 19:14:15.978: D/MyLog(8018): 				  	
07-16 19:14:15.978: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.978: D/MyLog(8018): text = World of Goo
07-16 19:14:15.978: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.978: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.978: D/MyLog(8018): text = 
07-16 19:14:15.978: D/MyLog(8018): 				  
07-16 19:14:15.978: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.978: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.978: D/MyLog(8018): text = 
07-16 19:14:15.978: D/MyLog(8018): 			
07-16 19:14:15.978: D/MyLog(8018): START_TAG: name = item
07-16 19:14:15.978: D/MyLog(8018): text = 
07-16 19:14:15.978: D/MyLog(8018): 				  	
07-16 19:14:15.978: D/MyLog(8018): START_TAG: name = lnk
07-16 19:14:15.988: D/MyLog(8018): text = http://home-android.ru/content/games/868/1369196082619275B.png
07-16 19:14:15.988: D/MyLog(8018): END_TAG: name = lnk
07-16 19:14:15.988: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.988: D/MyLog(8018): text = 
07-16 19:14:15.988: D/MyLog(8018): 				  	
07-16 19:14:15.988: D/MyLog(8018): START_TAG: name = name
07-16 19:14:15.988: D/MyLog(8018): text = Sonic The Hedgehog
07-16 19:14:15.988: D/MyLog(8018): END_TAG: name = name
07-16 19:14:15.988: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.988: D/MyLog(8018): text = 
07-16 19:14:15.988: D/MyLog(8018): 				  
07-16 19:14:15.988: D/MyLog(8018): END_TAG: name = item
07-16 19:14:15.988: D/MyLog(8018): publishProgress: name = ; lnk = 
07-16 19:14:15.988: D/MyLog(8018): text = 
07-16 19:14:15.988: D/MyLog(8018): 			
07-16 19:14:15.998: D/MyLog(8018): END_TAG: name = message
07-16 19:14:15.998: D/MyLog(8018): publishProgress: name = ; lnk =
0
V0v1k
1159 / 983 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:28 #18
так он закомментирован.
0
Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,189
Записей в блоге: 5
17.07.2013, 00:46  [ТС] #19
Цитата Сообщение от V0v1k Посмотреть сообщение
так он закомментирован.
да, но в логах, переменные name и lnk пустые....

Добавлено через 16 минут
Сделал так, и всеравно толку никакого:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
package com.t.test; 
 
import java.io.IOException; 
import java.io.InputStream; 
import java.net.URL; 
 
import org.xmlpull.v1.XmlPullParser; 
import org.xmlpull.v1.XmlPullParserException; 
import org.xmlpull.v1.XmlPullParserFactory; 
 
import android.os.AsyncTask; 
import android.os.Bundle; 
import android.app.Activity; 
import android.content.res.XmlResourceParser; 
import android.graphics.Bitmap; 
import android.graphics.BitmapFactory; 
import android.text.TextUtils;
import android.util.Log; 
import android.widget.ImageView; 
import android.widget.LinearLayout;
import android.widget.TextView; 
 
public class Main extends Activity { 
     
    public String TAG="MyLog";
    
    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
        super.onCreate(savedInstanceState); 
        
        setContentView(R.layout.main); 
        
        Log.d(TAG, "strat app TEST");
        
        AsyncDownloader downloader = new AsyncDownloader(); 
        
        Log.d(TAG, "AsyncDownloader");
        
        downloader.execute();  
        
        Log.d(TAG, "Execute AD");
    }  
     
    public void rec(String lnk, String name) 
    { 
         LinearLayout layout = (LinearLayout) findViewById(R.id.lin1);
         
         TextView txt = new TextView(this); 
         txt.setText(name); 
         layout.addView(txt);
         
         //ImageView image = new ImageView(this);
         //layout.addView(image);
        // new DownloadImageTask(image).execute(lnk);
    } 
     
     
    class AsyncDownloader extends AsyncTask<Object, String, Integer>{ 
 
        public String TAG="MyLog";
        
        @Override 
        protected Integer doInBackground(Object... params) { 
             
            XmlPullParser recivedData = null; 
            try { 
                recivedData = tryDownloadingXmlData(); 
            } catch (IOException e) { 
                // TODO Auto-generated catch block 
                e.printStackTrace(); 
            } 
            int recordsFound = 0; 
            try { 
                recordsFound = tryParsingXmlData(recivedData); 
            } catch (XmlPullParserException e) { 
                // TODO Auto-generated catch block 
                e.printStackTrace(); 
            } catch (IOException e) { 
                // TODO Auto-generated catch block 
                e.printStackTrace(); 
            } 
            return recordsFound; 
        } 
          
        private XmlPullParser tryDownloadingXmlData() throws IOException {     
            try{ 
            URL xmlUrl = new URL("http://home-android.ru/android/main"); 
            XmlPullParser recivedData = XmlPullParserFactory.newInstance().newPullParser(); 
            recivedData.setInput(xmlUrl.openStream(),null); 
            
            Log.d(TAG, "XML получен");
            
            return recivedData; 
            }  
            catch(XmlPullParserException e){ } 
            catch(IOException e) { } 
            return null; 
        } 
         
         
        private int tryParsingXmlData(XmlPullParser recivedData) throws XmlPullParserException, IOException { 
            if(recivedData != null) 
            { 
                processRecivedData(recivedData); 
            } 
            return 0; 
        } 
 
 
 
        private void processRecivedData(XmlPullParser xmlData) throws XmlPullParserException, IOException { 
            int eventType = -1; 
            int recordsFound = 0; 
             
            String lnk=""; 
            String name=""; 
            
            Log.d(TAG, "Старт парсинга XML");
             
            while(eventType!=XmlResourceParser.END_DOCUMENT) 
            { 
                String tagName=xmlData.getName(); 
                
                switch(eventType)  
                { 
                    case XmlResourceParser.START_TAG: 
                    Log.d(TAG, "START_TAG: name = " + xmlData.getName());     
                    break; 
                 
 
                  // содержимое тэга
                case XmlResourceParser.TEXT:
                     
                          Log.d(TAG, "Text = " + xmlData.getText());
                          
                          if(TextUtils.equals(tagName,"name")) {
                              name = xmlData.getText();
                          }
                          if(TextUtils.equals(tagName,"lnk")) {
                              lnk = xmlData.getText();
                          }
                          
                    break;
 
                  case XmlResourceParser.END_TAG:
                      Log.d(TAG, "END_TAG: name = " + xmlData.getName());
                      Log.d(TAG, "publishProgress: name = " +name+ "; lnk = " + lnk);
                      recordsFound++; 
                     publishProgress(lnk,name); 
                      
                      break;
                
                
 
                  default:  break;
                    
 
                } 
                eventType=xmlData.next(); 
                 
                if(recordsFound==0){ 
                    publishProgress(); 
                } 
            } 
             
             
             
        } 
 
         
        @Override 
        protected void onPostExecute(Integer result) { 
            super.onPostExecute(result); 
            //  код 
        } 
         
 
 
        @Override 
        protected void onProgressUpdate(String... values){ 
             
            if(values.length>1) 
            { 
                String lnk = values[0]; 
                String name = values[1];
                 
                    Main.this.rec(lnk,name); 
                 
            }
             
            super.onProgressUpdate(values); 
        } 
         
         
    }     
    
    
    
    
    
     
    class DownloadImageTask extends AsyncTask<String, Void, Bitmap> { 
        ImageView bmImage; 
 
        DownloadImageTask(ImageView bmImage) { 
            this.bmImage = bmImage; 
        } 
 
        protected Bitmap doInBackground(String... urls) { 
            String urldisplay = urls[0]; 
            Bitmap mIcon11 = null; 
            try { 
                InputStream in = new java.net.URL(urldisplay).openStream(); 
                mIcon11 = BitmapFactory.decodeStream(in); 
            } catch (Exception e) { 
                Log.e("Error", e.getMessage()); 
                e.printStackTrace(); 
            } 
            return mIcon11; 
        } 
 
        protected void onPostExecute(Bitmap result) { 
            bmImage.setImageBitmap(result); 
        } 
    } 
     
         
}
0
V0v1k
1159 / 983 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:52 #20
посмотрите по примеру что вы делаете не так - http://developer.android.com/referen...ullParser.html
0
Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,189
Записей в блоге: 5
17.07.2013, 00:56  [ТС] #21
Цитата Сообщение от V0v1k Посмотреть сообщение
посмотрите по примеру что вы делаете не так - http://developer.android.com/referen...ullParser.html
Я уже смотрел много примеров и перечитывал все по несколько раз, немогу понять, почему так переменные пустые:
Java
1
2
3
4
5
6
if(TextUtils.equals(tagName,"name")) {
                              name = xmlData.getText();  Log.d(TAG, "Text = " + xmlData.getText());
                          }
                          if(TextUtils.equals(tagName,"lnk")) {
                              lnk = xmlData.getText();   Log.d(TAG, "Text = " + xmlData.getText());
                          }
А если просто оставить строку:
Java
1
Log.d(TAG, "Text = " + xmlData.getText());
то в лог записываются нужные данные.....
Никак неразберусь((
0
chizz
981 / 496 / 54
Регистрация: 19.03.2013
Сообщений: 3,091
Записей в блоге: 18
Завершенные тесты: 1
17.07.2013, 10:58 #22
Когда ты заходишь в case XmlResourceParser.TEXT проверь какой там tagname, выведи его в logcat. Подозреваю, что будет null.
Тебе надо в case XmlResourceParser.START_TAG проверять tagname на item и в этом case лезть дальше в Text и забирать оттуда текст. И String tagName=xmlData.getName(); должно быть внутри START_TAG.

Например:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
int eventType = -1;
while(eventType != XmlResourceParser.END_DOCUMENT)
{
    XmlResourceParser assurances = getResources().getXml(R.xml.assurances); 
    String name = assurances.getText();
    Log.d(TAG, name);
 
    try {
        if (assurances.getEventType() == XmlResourceParser.START_TAG) {
            String s = assurances.getName();
 
            if (s.equals("assurance")) {
                assurances.next();   /// moving to the next node
                if(assurances.getName() != null && assurances.getName().equalsIgnoreCase("message")){
                    String strMessage = assurances.getText();  ///to get value getText() method should be used
                    assurances.next();   ///jumping on to the next node
                String strReference = assurances.getText();  ////similar to above
            }
 
                Log.d(TAG, strMessage);
                Log.d(TAG, strReference);
            }
        }
    } catch (XmlPullParserException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
}
1
17.07.2013, 10:58
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.07.2013, 10:58
Привет! Вот еще темы с ответами:

Bitmap не получает цвета с экрана - Программирование Android
делаю приложение которое работает с камерой через обьект SurfaceView, нужно при касании на экране получить цвет пикселя, выводил в лог и...

Клиент на Android не получает данные с сервера - Программирование Android
Сервер на компе, написан на .Net, клиент на Android, ставится на устройство. Находясь в одной сети клиент подключается к серверу на .Net,...

Неправильно получает данные скрипт. Подробнее внутри - JavaScript
Есть такой скрипт: v0=prompt(&quot;Введите начальную скорость&quot;, &quot;&quot;); sum=0; do{ sum=sum+(v0/3.6)*(v0/3.6); v0=v0+1; } while...

Как связывать отчет Crystal Report с абсолютным путем к БД, из которой он получает значения - C#
Как не связывать отчет Crystal Report с абсолютным путем к БД, из которой он получает значения? Ибо при переносе проекта на другой...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
22
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.