zoukankan      html  css  js  c++  java
  • Silverlight学习笔记十二动态加载图片和显示提示(ToolTip)

    这一节是如何动态加载图片和显示提示(ToolTip)

    下面是效果

     1.LayoutControlDemo.xaml

    <UserControl   xmlns:my1="clr-namespace:DevExpress.Xpf.LayoutControl;assembly=DevExpress.Xpf.LayoutControl.v10.1"    
        xmlns:toolkit="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data.DataForm.Toolkit"  xmlns:my="clr-namespace:Silverlight.Common.View"  xmlns:dx="clr-namespace:DevExpress.Xpf.Core;assembly=DevExpress.Xpf.Core.v10.1"  x:Class="Silverlight.Common.View.LayoutControlDemo"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
                   xmlns:controls="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls"
        mc:Ignorable="d"
        d:DesignHeight="300" d:DesignWidth="400">

        <Grid x:Name="LayoutRoot" Background="White">

            <StackPanel  x:Name="panel" FlowDirection="LeftToRight" HorizontalAlignment="Left" VerticalAlignment="Top" Orientation="Horizontal">

            </StackPanel>
        </Grid>

    </UserControl>

    2.LayoutControlDemo.cs

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Animation;
    using System.Windows.Shapes;
    using Silverlight.Common.Core;
    using System.Windows.Media.Imaging;
    using System.Collections.ObjectModel;
    using System.Windows.Controls.Primitives;
    using DevExpress.Xpf.Core;

    namespace Silverlight.Common.View
    {
        public partial class LayoutControlDemo : UserControl
        {
            Star star = new Star();
            public LayoutControlDemo()
            {
                InitializeComponent();
                InitPanel();
            }

            /// <summary>
            /// 初始化界面
            /// </summary>
            void InitPanel()
            {
                ObservableCollection<Star> list = null;

                list = star.DataSource();

                if (list != null)
                {
                    foreach (var item in list)
                    {
                        Image image = new Image();
                        image.Width = (double)100;
                        image.Height = (double)100;
                       
                        //图片地址
                        image.Source = item.Image;

                        //图片标识
                        image.Tag = item.Tag;

                        //将此控件添加到布局控件上
                        panel.Children.Add(image);

                        //ToopTip对象
                        ToolTip tt = new ToolTip();
                        Info info=new Info();

                        //给ToolTip的Content赋值
                        tt.Content = info;

                        //设置image的ToolTip
                        image.SetToolTip(tt);

                        tt.DataContext = star.Get(image.Tag.ToString());
                    }
                }
            }
        }
    }

    3.Info.xaml

    <UserControl xmlns:dxe="clr-namespace:DevExpress.Xpf.Editors;assembly=DevExpress.Xpf.Core.v10.1"  x:Class="Silverlight.Common.View.Info"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        mc:Ignorable="d" d:DesignHeight="100" d:DesignWidth="200"
         >

        <Grid x:Name="LayoutRoot" Background="White">
            <Grid.RowDefinitions>
                <RowDefinition  Height="23"/>
                <RowDefinition  Height="23"/>
                <RowDefinition  Height="23"/>
                <RowDefinition  Height="15"/>
                <RowDefinition />
            </Grid.RowDefinitions>
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="auto"/>
                <ColumnDefinition Width="auto"/>
            </Grid.ColumnDefinitions>
            <TextBlock Text="{Binding MovieName}"></TextBlock>
            <TextBlock Grid.Column="1" Text="{Binding MovieType}"></TextBlock>
            <TextBlock Grid.Row="1" Text="主演:"></TextBlock>
            <TextBlock Grid.Row="1" Grid.Column="2" Text="{Binding Starring}"></TextBlock>
            <TextBlock Grid.Row="2"  Text="地区:"></TextBlock>
            <TextBlock Grid.Row="2" Grid.Column="2" Text="{Binding Area}"></TextBlock>
            <TextBlock Grid.Row="3"  Text="剧情:" Grid.ColumnSpan="2"></TextBlock>
            <TextBox TextWrapping="Wrap" BorderThickness="0" Grid.Row="4" Grid.ColumnSpan="2"  Width="200" Text="{Binding Plot}"></TextBox>
        
        </Grid>
    </UserControl>

    4.Star.cs

    using System;
    using System.Net;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Documents;
    using System.Windows.Ink;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Animation;
    using System.Windows.Shapes;
    using System.Windows.Media.Imaging;
    using System.Collections.ObjectModel;

    using System.Linq;

    namespace Silverlight.Common.Core
    {
        public class Star
        {
            /// <summary>
            /// 标识
            /// </summary>
            public string Tag { get; set; }

            /// <summary>
            /// 主演
            /// </summary>
            public string Starring { get; set; }

            /// <summary>
            /// 电影名
            /// </summary>
            public string MovieName { get; set; }

            /// <summary>
            /// 所属地区
            /// </summary>
            public string Area { get; set; }

            /// <summary>
            /// 图片名字
            /// </summary>
            public string ImageName { get; set; }

            /// <summary>
            /// 图片
            /// </summary>
            public BitmapImage Image { get { return new BitmapImage(ImageFullName); } }

            /// <summary>
            /// 图片路径
            /// </summary>
            public string ImagesPath { get; set; }

            /// <summary>
            /// 图片全名
            /// </summary>
            public Uri ImageFullName {
                get { return new Uri(ImagesPath + ImageName, UriKind.Relative); }}
         
            /// <summary>
            /// 电影类型
            /// </summary>
            public string MovieType { get; set; }

            /// <summary>
            /// 剧情
            /// </summary>
            public string Plot { get; set; }

         // public  ObservableCollection<BitmapImage> images { get { return m_images; } }

            public  ObservableCollection<Star> DataSource()
            {
                ObservableCollection<Star> list = new ObservableCollection<Star>();
                list.Add(new Star()
                {
                    Tag="SadStory",
                    Starring = "权相宇,金喜善",
                    Area="韩国",
                    MovieName = "悲伤恋歌",
                    MovieType = "爱情/悲剧",
                    Plot = "三个人的爱情,三个人的悲剧",
                    ImageName="ba.jpg",
                    ImagesPath = "../Images/",
                });

                list.Add(new Star()
                {
                    Tag = "da",
                    Starring = "权相宇,李瑶媛",
                    Area = "韩国",
                    MovieName = "毒爱",
                    MovieType = "爱情/悲剧",
                    Plot = "这部电影是权相宇结婚后的首部悲剧电视剧,讲述了俩个都被爱所伤害的人,相遇后的故事!",
                    ImageName = "da.jpg",
                    ImagesPath = "../Images/",
                });

                list.Add(new Star()
                {
                    Tag = "sm",
                    Starring = "权相宇,宋承宪",
                    Area = "韩国",
                    MovieName = "宿命",
                    MovieType = "爱情/悲剧",
                    Plot = "讲述了三个挚友为了钱而互相残杀的故事!",
                    ImageName = "sm.jpg",
                    ImagesPath = "../Images/",
                });

                list.Add(new Star()
                {
                    Tag = "jt",
                    Starring = "权相宇,崔智友",
                    Area = "韩国",
                    MovieName = "天堂的阶梯",
                    MovieType = "爱情/悲剧",
                    Plot = "诚俊和静书是青梅竹马的玩伴,从小如同亲兄妹般渡过孩童时期。每当静书伤心难过时,诚俊总会守在她身边付出关心,而静书同样依赖诚俊,使两人对彼此逐渐培养出男女之情。天国的阶梯某一天诚俊之父车祸身亡,不久之后静书之母也因病过世。",
                    ImageName = "jt.jpg",
                    ImagesPath = "../Images/",
                });

                list.Add(new Star()
                {
                    Tag = "wz",
                    Starring = "权相宇,允儿",
                    Area = "韩国",
                    MovieName = "乞丐变王子",
                    MovieType = "爱情",
                    Plot = " 这次公开的剧照描绘了背着大包在东大门市场工作的吴大山(权相宇 饰)和父亲去世后坐在父亲的店里看着家人照片的徐柳真(允儿 饰)的样子。剧中柳真在父亲的葬礼上跟大山擦肩而过,而两人在柳真父亲的店里又再次相遇。大山帮助陷入困境的柳真,两人的因缘由此展开。",
                    ImageName = "wz.jpg",
                    ImagesPath = "../Images/",
                });
           
                return list;
            }

            public Star Get(string Tag)
            {
                Star obj = null;
                if (this.DataSource().Where(w => w.Tag == Tag) != null)
                {
                    obj = this.DataSource().Where(w => w.Tag == Tag).First();
                }
             
                return obj;
            }       
        }
    }

    注:TextBox的多行属性TextWrapping="Wrap"很重要啊。

      界面做的很不好看,请大家谅解啊

    源代码下载:https://files.cnblogs.com/salam/Silverlight.Common.rar

  • 相关阅读:
    父级设置display:flex;子级宽度无效的解决办法
    小程序注意事项
    css 字体默认有高度 怎么去掉
    小程序长按识别问题
    css 列表多列多行 同行等高样式
    AndroidManifest.xml:90: error: Error: String types not allowed (at 'largeHeap' with value 'auto').
    10.4.2 ListView.ScrollViewChange存在的问题
    【转】UniTreeMenu控件不显示滚动条的解决办法
    Delphi 10.4.2拍照遇到的新问题
    ChinaCock 用CCShortcutBadger组件显示角标
  • 原文地址:https://www.cnblogs.com/salam/p/1779648.html
Copyright © 2011-2022 走看看