Форум программистов, компьютерный форум CyberForum.ru

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.67
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
16.07.2013, 11:02     XmlPullParser неправильно получает значения #1
Здравствуйте. Пытаюсь написать обработку 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); 
        } 
    } 
     
         
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Wenceslaus
Android Developer
 Аватар для Wenceslaus
129 / 129 / 4
Регистрация: 05.07.2013
Сообщений: 205
16.07.2013, 12:13     XmlPullParser неправильно получает значения #2
Лог с ошибкой в студию. Код на первый взгляд верный..
V0v1k
1157 / 981 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
16.07.2013, 12:14     XmlPullParser неправильно получает значения #3
а где корневой тэг?
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
16.07.2013, 12:28  [ТС]     XmlPullParser неправильно получает значения #4
Цитата Сообщение от V0v1k Посмотреть сообщение
а где корневой тэг?
Начинается с этого:
XML
1
<?xml version="1.0" encoding="utf-8"?>
я показал часть кода, или нужно обернуть все в еще один тег?

Добавлено через 9 минут
Цитата Сообщение от Wenceslaus Посмотреть сообщение
Лог с ошибкой в студию. Код на первый взгляд верный..
Чегото я немогу найти в консоле текста с ошибкой, в DDMS пусто, а в Android вот то что пишет:
[2013-07-16 11:27:01 - test] ------------------------------
[2013-07-16 11:27:01 - test] Android Launch!
[2013-07-16 11:27:01 - test] adb is running normally.
[2013-07-16 11:27:01 - test] Performing com.t.test.Main activity launch
[2013-07-16 11:27:01 - test] Automatic Target Mode: using device '4df12d29285c9fef'
[2013-07-16 11:27:01 - test] Uploading test.apk onto device '4df12d29285c9fef'
[2013-07-16 11:27:01 - test] Installing test.apk...
[2013-07-16 11:27:05 - test] Success!
[2013-07-16 11:27:05 - test] Starting activity com.t.test.Main on device 4df12d29285c9fef
[2013-07-16 11:27:05 - test] ActivityManager: Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.t.test/.Main }
Wenceslaus
Android Developer
 Аватар для Wenceslaus
129 / 129 / 4
Регистрация: 05.07.2013
Сообщений: 205
16.07.2013, 12:45     XmlPullParser неправильно получает значения #5
Цитата Сообщение от Sanu0074 Посмотреть сообщение
Чегото я немогу найти в консоле текста с ошибкой, в DDMS пусто, а в Android вот то что пишет:
В LogCat пусто? Фильтров никаких не используете? Если что-то есть, выкладывайте весь лог и приблизительную дату запуска. (Console здесь не поможет).
chizz
 Аватар для chizz
979 / 493 / 54
Регистрация: 19.03.2013
Сообщений: 3,059
Записей в блоге: 18
Завершенные тесты: 1
16.07.2013, 12:52     XmlPullParser неправильно получает значения #6
Цитата Сообщение от V0v1k Посмотреть сообщение
а где корневой тэг?
Где корень у входного xml?
Приведите xml к структуре типа
XML
1
2
3
4
5
6
7
<root>
<item>
  <lnk/>
  <name/>
</item>
.....
</root>
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
16.07.2013, 15:57  [ТС]     XmlPullParser неправильно получает значения #7
Цитата Сообщение от chizz Посмотреть сообщение
Где корень у входного xml?
Приведите xml к структуре типа
XML
1
2
3
4
5
6
7
<root>
<item>
  <lnk/>
  <name/>
</item>
.....
</root>
Сделал, теперь так:
XML
1
2
3
4
5
6
7
8
9
10
<message>
 <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>
</message>
Но ничего не изменилось, вылет как был, так и остался...

Добавлено через 2 часа 57 минут
Цитата Сообщение от Wenceslaus Посмотреть сообщение
В LogCat пусто? Фильтров никаких не используете? Если что-то есть, выкладывайте весь лог и приблизительную дату запуска. (Console здесь не поможет).
Log.d(TAG, lnk); - Ничего не записывает, вобще он раз сработал и все.... висит постоянно одно и тоже((( Скопируй себе и запусти если интересно может у тебя получится, сижу уже 3 часа немогу найти ошибку, перечитал все что только можно
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
16.07.2013, 15:59  [ТС]     XmlPullParser неправильно получает значения #8
Выкладываю проект:
Вложения
Тип файла: rar test.rar (1.06 Мб, 2 просмотров)
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
16.07.2013, 21:58  [ТС]     XmlPullParser неправильно получает значения #9
Переделал прогу, натыкал логов, всеравно немогу понять где ошибка, вот код:
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
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 { 
     
    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(); 
                
                Log.d(TAG, "tagName = "+tagName);
                
                switch(eventType) 
                { 
                case XmlResourceParser.START_TAG: 
                    if(tagName.equals("lnk") || tagName.equals("name")) 
                    { 
                        continue;
                    } 
                break; 
                 
                case XmlResourceParser.TEXT: 
                    if (tagName.equals("lnk")) {
                        lnk=xmlData.getText(); 
                         Log.d(TAG, "lnk = "+lnk);
                        
                    }
                    if (tagName.equals("name")) {
                        name = xmlData.getText();
                        Log.d(TAG, "name = "+name);
                    }
                break; 
                 
                 
                case XmlResourceParser.END_TAG: 
                    if(tagName.equals("item"))  
                    { 
                        recordsFound++; 
                        publishProgress(lnk,name); 
                        Log.d(TAG, "PUBLISH: name = "+name+"; lnk = "+lnk);
                    } 
                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); 
        } 
    } 
     
         
}
Вот лог:
Код
07-16 17:56:21.728: E/Trace(3387): error opening trace file: No such file or directory (2)
07-16 17:56:22.488: D/MyLog(3387): strat app TEST
07-16 17:56:22.488: D/MyLog(3387): AsyncDownloader
07-16 17:56:22.488: D/MyLog(3387): Execute AD
07-16 17:56:22.568: D/gralloc_goldfish(3387): Emulator without GPU emulation detected.
07-16 17:56:26.327: D/MyLog(3387): XML получен
07-16 17:56:26.327: D/MyLog(3387): Старт парсинга XML
07-16 17:56:26.327: D/MyLog(3387): tagName = null
07-16 17:56:26.337: D/MyLog(3387): tagName = message
07-16 17:56:26.337: D/MyLog(3387): tagName = item
07-16 17:56:26.337: D/MyLog(3387): tagName = null
07-16 17:56:26.337: W/dalvikvm(3387): threadid=11: thread exiting with uncaught exception (group=0x40a13300)
07-16 17:56:26.357: E/AndroidRuntime(3387): FATAL EXCEPTION: AsyncTask #1
07-16 17:56:26.357: E/AndroidRuntime(3387): java.lang.RuntimeException: An error occured while executing doInBackground()
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at android.os.AsyncTask$3.done(AsyncTask.java:299)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at java.util.concurrent.FutureTask.run(FutureTask.java:137)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at java.lang.Thread.run(Thread.java:856)
07-16 17:56:26.357: E/AndroidRuntime(3387): Caused by: java.lang.NullPointerException
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at com.t.test.Main$AsyncDownloader.processRecivedData(Main.java:135)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at com.t.test.Main$AsyncDownloader.tryParsingXmlData(Main.java:103)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at com.t.test.Main$AsyncDownloader.doInBackground(Main.java:73)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at com.t.test.Main$AsyncDownloader.doInBackground(Main.java:1)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at android.os.AsyncTask$2.call(AsyncTask.java:287)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
07-16 17:56:26.357: E/AndroidRuntime(3387): 	... 5 more
Немогу разобраться, помогите пожалуйста
V0v1k
1157 / 981 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
16.07.2013, 23:40     XmlPullParser неправильно получает значения #10
Цитата Сообщение от Sanu0074 Посмотреть сообщение
tagName = null
вы логи для красоты писали?
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
16.07.2013, 23:58  [ТС]     XmlPullParser неправильно получает значения #11
Цитата Сообщение от 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
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
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:
                    if (tagName.equals("lnk") && tagName.equals("name")){
                      Log.d(TAG, "text = " + 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;
                    
 
                } 
                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); 
        } 
    } 
     
         
}
и лог:
Код
07-16 18:50:36.338: E/Trace(6532): error opening trace file: No such file or directory (2)
07-16 18:50:36.869: D/MyLog(6532): strat app TEST
07-16 18:50:36.869: D/MyLog(6532): AsyncDownloader
07-16 18:50:36.879: D/MyLog(6532): Execute AD
07-16 18:50:36.958: D/gralloc_goldfish(6532): Emulator without GPU emulation detected.
07-16 18:50:37.568: I/Choreographer(6532): Skipped 98 frames!  The application may be doing too much work on its main thread.
07-16 18:50:38.767: D/MyLog(6532): XML получен
07-16 18:50:38.767: D/MyLog(6532): Старт парсинга XML
07-16 18:50:38.777: D/MyLog(6532): START_TAG: name = message
07-16 18:50:38.777: D/MyLog(6532): START_TAG: name = item
07-16 18:50:38.777: W/dalvikvm(6532): threadid=11: thread exiting with uncaught exception (group=0x40a13300)
07-16 18:50:38.897: E/AndroidRuntime(6532): FATAL EXCEPTION: AsyncTask #1
07-16 18:50:38.897: E/AndroidRuntime(6532): java.lang.RuntimeException: An error occured while executing doInBackground()
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at android.os.AsyncTask$3.done(AsyncTask.java:299)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at java.util.concurrent.FutureTask.run(FutureTask.java:137)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at java.lang.Thread.run(Thread.java:856)
07-16 18:50:38.897: E/AndroidRuntime(6532): Caused by: java.lang.NullPointerException
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at com.t.test.Main$AsyncDownloader.processRecivedData(Main.java:133)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at com.t.test.Main$AsyncDownloader.tryParsingXmlData(Main.java:104)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at com.t.test.Main$AsyncDownloader.doInBackground(Main.java:74)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at com.t.test.Main$AsyncDownloader.doInBackground(Main.java:1)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at android.os.AsyncTask$2.call(AsyncTask.java:287)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
07-16 18:50:38.897: E/AndroidRuntime(6532): 	... 5 more
V0v1k
1157 / 981 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:01     XmlPullParser неправильно получает значения #12
что переписали? как не было проверки на null так и нету.
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
17.07.2013, 00:02  [ТС]     XmlPullParser неправильно получает значения #13
Цитата Сообщение от V0v1k Посмотреть сообщение
что переписали? как не было проверки на null так и нету.
ладно, конкретнее, где что проверять?
V0v1k
1157 / 981 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:10     XmlPullParser неправильно получает значения #14
Цитата Сообщение от Sanu0074 Посмотреть сообщение
Main.java:133
вот же, в логах все написано.
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
17.07.2013, 00:12  [ТС]     XmlPullParser неправильно получает значения #15
Цитата Сообщение от V0v1k Посмотреть сообщение
вот же, в логах все написано.
я понял что здесь ошибка: if (tagName.equals("lnk") && tagName.equals("name"))
но что тут не так?
V0v1k
1157 / 981 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:14     XmlPullParser неправильно получает значения #16
ну вот же
tagName = null
NullPointerException
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
17.07.2013, 00:23  [ТС]     XmlPullParser неправильно получает значения #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 =
V0v1k
1157 / 981 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:28     XmlPullParser неправильно получает значения #18
так он закомментирован.
Sanu0074
 Аватар для Sanu0074
58 / 58 / 2
Регистрация: 14.06.2010
Сообщений: 1,186
Записей в блоге: 5
17.07.2013, 00:46  [ТС]     XmlPullParser неправильно получает значения #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); 
        } 
    } 
     
         
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.07.2013, 00:52     XmlPullParser неправильно получает значения
Еще ссылки по теме:

Android Неправильно составлен конструктор
Нужен пример работы Socked клиента, который получает некую инфу от сервера Android
Android Bitmap не получает цвета с экрана
RSS reader by XmlPullParser + Listview Android
Android Nine patch - неправильно растягивается

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

Или воспользуйтесь поиском по форуму:
V0v1k
1157 / 981 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:52     XmlPullParser неправильно получает значения #20
посмотрите по примеру что вы делаете не так - http://developer.android.com/referen...ullParser.html
Yandex
Объявления
17.07.2013, 00:52     XmlPullParser неправильно получает значения
Ответ Создать тему
Опции темы

Текущее время: 18:09. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru