利用webxml来构建wp的天气预报

在wp里,我们可以根据一些网站的API来达到一些目的。例如获取天气预报就是这样。在http://www.webxml.com.cn/zh_cn/index.aspx这个网址里提供一些api供我们使用。

首先,新建一个项目,然后修改前台界面代码。

View Code
<Grid x:Name="LayoutRoot">
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto"/>
            <RowDefinition Height="*"/>
        </Grid.RowDefinitions>
        <!--ContentPanel - place additional content here-->
        <Grid x:Name="ContentPanel" Grid.Row="0" Margin="12,0,12,0">
            <Button  Height="72" HorizontalAlignment="Left" Margin="354,97,0,0" Name="btn_search" VerticalAlignment="Top" Width="72" Click="btn_search_Click" BorderBrush="Black">
                <Button.Background>
                    <ImageBrush ImageSource="/wp7-weather;component/Images/search.png" />
                </Button.Background>
            </Button>
            <TextBox Height="72" HorizontalAlignment="Left" Margin="12,42,0,0" Name="txt_search" VerticalAlignment="Top" Width="438" Opacity="1" />
            <TextBlock Height="34" HorizontalAlignment="Left" Margin="24,20,0,0" Name="textBlock1" Text="请输入你要查询天气的城市名:" VerticalAlignment="Top" Foreground="Black"></TextBlock>
        </Grid>
        <StackPanel Orientation="Vertical" Grid.Row="1">
            <ListBox>
            <StackPanel Orientation="Horizontal">
                <Image Width="100" Height="100" Name="img_today" Margin="40,10,5,0"></Image>
                <StackPanel Orientation="Vertical">
                        <TextBlock x:Name="lbl_today" Text="" FontSize="32" Margin="50,10,0,0" VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_wind" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_temp" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                </StackPanel>
            </StackPanel>
            <StackPanel Orientation="Horizontal">
                    <Image Width="100" Height="100" Name="img_today1" Margin="40,10,5,0"></Image>
                <StackPanel Orientation="Vertical">
                        <TextBlock x:Name="lbl_today1" Text="" FontSize="32" Margin="50,10,0,0" VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_wind1" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_temp1" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                </StackPanel>
            </StackPanel>
                <StackPanel Orientation="Horizontal">
                    <Image Width="100" Height="100" Name="img_today2" Margin="40,10,5,0"></Image>
                    <StackPanel Orientation="Vertical">
                        <TextBlock x:Name="lbl_today2" Text="" FontSize="32" Margin="50,10,0,0" VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_wind2" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_temp2" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                    </StackPanel>
                </StackPanel>
                <StackPanel Orientation="Horizontal">
                    <Image Width="100" Height="100" Name="img_today3" Margin="40,10,5,0"></Image>
                    <StackPanel Orientation="Vertical">
                        <TextBlock x:Name="lbl_today3" Text="" FontSize="32" Margin="50,10,0,0" VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_wind3" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_temp3" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                    </StackPanel>
                </StackPanel>
                <StackPanel Orientation="Horizontal">
                    <Image Width="100" Height="100" Name="img_today4" Margin="40,10,5,0"></Image>
                    <StackPanel Orientation="Vertical">
                        <TextBlock x:Name="lbl_today4" Text="" FontSize="32" Margin="50,10,0,0" VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_wind4" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                        <TextBlock x:Name="lbl_temp4" Text=""  FontSize="32" Margin="50,0,0,0"  VerticalAlignment="Center" Foreground="Black"/>
                    </StackPanel>
                </StackPanel>
            </ListBox>
        </StackPanel>
        <Grid.Background>
            <ImageBrush ImageSource="/wp7-weather;component/Images/water.png" />
        </Grid.Background>
    </Grid>

打开上面那个网址,我们可以看到下面有一个2500城市天气预报,点击进去,可以看到有很多方法供我们调用:

我们需要的就是下面的getWeather这个方法。

点击进去之后随便输入一个城市,返回给我们的是xml格式的信息:

接下来,回到项目,添加一个服务引用,地址就是上面2500城市天气的网址。

添加完之后我们就可以实现api的调用了。

在后台添加好相应的对象实例化,同时实例化一个list来存放反馈的信息

ServiceReference1.WeatherWSSoapClient w = new ServiceReference1.WeatherWSSoapClient();
List<string> msg = new List<string>();

然后在按钮事件里获取要查询的城市名称并异步发送,同时接收返回信息:

private void btn_search_Click(object sender, RoutedEventArgs e)
        {
            w.getWeatherAsync(txt_search.Text.ToString(), "");
            w.getWeatherCompleted += new EventHandler<ServiceReference1.getWeatherCompletedEventArgs>(w_getWeatherCompleted);
        }

上面的getWeatherAsync的两个参数就是城市名和id,id可以忽略为空。

w_getWeatherCompleted方法:

View Code
void w_getWeatherCompleted(object sender, ServiceReference1.getWeatherCompletedEventArgs e)
        {
            if (e.Error == null)
            {
                try
                {
                    for (int i = 0; i < e.Result.Length; i++)
                    {
                        string s = e.Result[i];
                        msg.Add(s);
                    }
                    if (msg.Count > 0)
                    {
                        setMsg();
                    }
                }
                catch (Exception)
                {
                    MessageBox.Show("灰常遗憾,亲,网络有误或者地名有误~");
                }
            }
            
        }

然后再在后台调用一个方法给前台的控件赋值(在这里我图方便,所以用了很多控件,其实可以用一个listbox来解决的。不过这里就不重复了)。

同时,我们根据返回的字符串来绑定相应的图片,图片的命名格式我也改了,随后会在代码附件里有。

View Code
public void setMsg()
        {
            lbl_today.Text = msg[7];
            lbl_temp.Text = msg[8];
            lbl_wind.Text = msg[9];
            img_today.Source = setImg(msg[10]);

            lbl_today1.Text = msg[12];
            lbl_temp1.Text = msg[13];
            lbl_wind1.Text = msg[14];
            img_today1.Source = setImg(msg[15]);

            lbl_today2.Text = msg[17];
            lbl_temp2.Text = msg[18];
            lbl_wind2.Text = msg[19];
            img_today2.Source = setImg(msg[20]);

            lbl_today3.Text = msg[22];
            lbl_temp3.Text = msg[23];
            lbl_wind3.Text = msg[24];
            img_today3.Source = setImg(msg[25]);

            lbl_today4.Text = msg[27];
            lbl_temp4.Text = msg[28];
            lbl_wind4.Text = msg[29];
            img_today4.Source = setImg(msg[30]);
        }
        public BitmapImage setImg(string str)
        {
            Uri uri = new Uri("Images/" + str.Substring(0, str.IndexOf('.')) + ".png", UriKind.Relative);
            BitmapImage bmp = new BitmapImage(uri);
            return bmp;
        }

 编译运行就可以了。

代码附件:http://dl.vmall.com/c0av1w2cmb 

 

 

posted @ 2013-04-07 19:33  Dieaz5  阅读(1098)  评论(10编辑  收藏  举报