Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.64/14: Рейтинг темы: голосов - 14, средняя оценка - 4.64
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
1

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

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

Author24 — интернет-сервис помощи студентам
Здравствуйте. Пытаюсь написать обработку 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.07.2013, 11:02
Ответы с готовыми решениями:

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

Изменения в XmlPullParser
Сегодня в почте увидел письмо от Гугла, что следует перейти на новую версию рекламного движка, так...

Самозакрывающийся тег XmlPullParser
Здравствуйте уважаемые форумчане! Возникла проблемка: не могу спарсить самозакрывающийся тег: ...

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

21
Android Developer
131 / 131 / 6
Регистрация: 05.07.2013
Сообщений: 205
16.07.2013, 12:13 2
Лог с ошибкой в студию. Код на первый взгляд верный..
0
1162 / 986 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
16.07.2013, 12:14 3
а где корневой тэг?
1
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
16.07.2013, 12:28  [ТС] 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 }
0
Android Developer
131 / 131 / 6
Регистрация: 05.07.2013
Сообщений: 205
16.07.2013, 12:45 5
Цитата Сообщение от Sanu0074 Посмотреть сообщение
Чегото я немогу найти в консоле текста с ошибкой, в DDMS пусто, а в Android вот то что пишет:
В LogCat пусто? Фильтров никаких не используете? Если что-то есть, выкладывайте весь лог и приблизительную дату запуска. (Console здесь не поможет).
0
993 / 521 / 102
Регистрация: 19.03.2013
Сообщений: 3,114
Записей в блоге: 19
16.07.2013, 12:52 6
Цитата Сообщение от V0v1k Посмотреть сообщение
а где корневой тэг?
Где корень у входного xml?
Приведите xml к структуре типа
XML
1
2
3
4
5
6
7
<root>
<item>
  <lnk/>
  <name/>
</item>
.....
</root>
0
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
16.07.2013, 15:57  [ТС] 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 часа немогу найти ошибку, перечитал все что только можно
0
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
16.07.2013, 15:59  [ТС] 8
Выкладываю проект:
Вложения
Тип файла: rar test.rar (1.06 Мб, 3 просмотров)
0
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
16.07.2013, 21:58  [ТС] 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
Немогу разобраться, помогите пожалуйста
0
1162 / 986 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
16.07.2013, 23:40 10
Цитата Сообщение от Sanu0074 Посмотреть сообщение
tagName = null
вы логи для красоты писали?
0
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
16.07.2013, 23:58  [ТС] 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
0
1162 / 986 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:01 12
что переписали? как не было проверки на null так и нету.
0
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
17.07.2013, 00:02  [ТС] 13
Цитата Сообщение от V0v1k Посмотреть сообщение
что переписали? как не было проверки на null так и нету.
ладно, конкретнее, где что проверять?
0
1162 / 986 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:10 14
Цитата Сообщение от Sanu0074 Посмотреть сообщение
Main.java:133
вот же, в логах все написано.
1
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
17.07.2013, 00:12  [ТС] 15
Цитата Сообщение от V0v1k Посмотреть сообщение
вот же, в логах все написано.
я понял что здесь ошибка: if (tagName.equals("lnk") && tagName.equals("name"))
но что тут не так?
0
1162 / 986 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:14 16
ну вот же
tagName = null
NullPointerException
1
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 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
1162 / 986 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:28 18
так он закомментирован.
0
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 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
1162 / 986 / 1
Регистрация: 28.06.2012
Сообщений: 3,462
17.07.2013, 00:52 20
посмотрите по примеру что вы делаете не так - http://developer.android.com/r... arser.html
0
17.07.2013, 00:52
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.07.2013, 00:52
Помогаю со студенческими работами здесь

PHP не получает значения из бд
У меня в бд 1 таблица, в которой 1 строка, 1 столбец, в нём значение gbe4utgghvnzdioyhn58ozy ...

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

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

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


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru