TipWindow.xaml_1118

本文介绍了一种自定义ToolTip控件的实现方法,该控件能够跟随鼠标移动并显示提示信息,同时根据浏览器分辨率调整位置,确保始终可见。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前台

<UserControl x:Class="ComputerDropDragControl.TipWindow"
    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="300" d:DesignWidth="400">

    <Grid x:Name="LayoutRoot" Background="White" >
        <!--<Grid.Resources>
            <Storyboard x:Name="stortBoardOne" x:Key="storyBoardOne" Completed="stortBoardOne_Completed"></Storyboard>
        </Grid.Resources>-->
        <Popup x:Name="tip" MouseMove="tip_MouseMove">
            <Grid x:Name="toolTip" Width="300" Height="220" Opacity="0.8">
                <Grid.Background>
                    <ImageBrush ImageSource="Img/tipWindowOne.png" x:Name="imageBrushOne"></ImageBrush>
                </Grid.Background>
                <Grid.RowDefinitions>
                    <RowDefinition  Height="auto"/>
                    <RowDefinition />
                </Grid.RowDefinitions>
                <Grid.ColumnDefinitions>
                    <ColumnDefinition Width="auto"/>
                </Grid.ColumnDefinitions>
                <TextBlock Grid.Row="0" Grid.Column="0" x:Name="mainContent"
                           Foreground="Black" FontSize="14" Height="Auto" HorizontalAlignment="Left"  Margin="10,10,10,0"
                           VerticalAlignment="Top" TextWrapping="Wrap"  Width="200"/>
            </Grid>
        </Popup>
    </Grid>
</UserControl>

后台

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 System.Threading;
using System.Windows.Media.Imaging;
using System.Windows.Browser;

namespace ComputerDropDragControl
{
    /// <summary>
    /// 提示框
    /// 创建人:吴兆娟
    /// 创建时间:2011-11-4
    /// </summary>
    public partial class TipWindow : UserControl
    {
        #region <<页面加载>>

        /// <summary>
        /// 页面加载
        /// </summary>
        public TipWindow()
        {
            InitializeComponent();

            //定时器
            //this.stortBoardOne.Duration = new TimeSpan(0, 0, 0, 2, 0);

            mainContent.Foreground = new SolidColorBrush(Colors.Black);
            mainContent.Text = "这种ToolTip是是是到nsk电脑上开始看神道贺就" + DateTime.Now.Millisecond;

        }

        #endregion

        #region <<控件事件>>

        ///// <summary>
        ///// “定时器完成时”发生的事件
        ///// </summary>
        ///// <param name="sender"></param>
        ///// <param name="e"></param>
        //private void stortBoardOne_Completed(object sender, EventArgs e)
        //{

        //}

        #endregion

        #region <<辅助方法>>

        public void BindControl(UIElement uc, NodeFrameView entity)
        {
            uc.MouseLeave += new MouseEventHandler(ti_MouseLeave);
            uc.MouseMove += new MouseEventHandler(ti_MouseMove);
        }


        public void CancelBindControl(UIElement uc)
        {
            this.tip.IsOpen = false;
            uc.MouseLeave -= new MouseEventHandler(ti_MouseLeave);
            uc.MouseMove -= new MouseEventHandler(ti_MouseMove);
        }

        /// <summary>       
        /// 鼠标离开自定义控件时,隐藏提示框      
        /// </summary>       
        /// <param name="sender"></param>       
        /// <param name="e"></param>
        private void ti_MouseLeave(object sender, MouseEventArgs e)
        {
            this.tip.IsOpen = false;
        }

        /// <summary>      
        /// 鼠标在自定义控件上移动式时,提示框也跟随移动     
        /// </summary>       
        ///<param name="sender"></param>       
        /// <param name="e"></param>       
        private void ti_MouseMove(object sender, MouseEventArgs e)
        {
            this.tip.IsOpen = true;


            //获取浏览器分辨率信息
            ScriptObject screen = (ScriptObject)HtmlPage.Window.GetProperty("screen");
            double width = (double)screen.GetProperty("width");
            double height = (double)screen.GetProperty("height");
            double mouseX = e.GetPosition(null).X;
            double mouseY = e.GetPosition(null).Y;

            double screenRight = width - mouseX - toolTip.Width - 20;
            double screenTop = mouseY - toolTip.Height;

            if (screenTop < 0 && screenRight > 0)
            {
                this.imageBrushOne.ImageSource = new BitmapImage(new Uri("Img/tipWindowTwo.png", UriKind.Relative));
                this.tip.HorizontalOffset = e.GetPosition(null).X - 20;
                this.tip.VerticalOffset = e.GetPosition(null).Y;

                mainContent.Margin = new Thickness(10, 50, 10, 0);
            }
            else if (screenRight < 0 && screenTop > 0)
            {
                this.imageBrushOne.ImageSource = new BitmapImage(new Uri("Img/tipWindowFour.png", UriKind.Relative));
                this.tip.HorizontalOffset = e.GetPosition(null).X - 275;
                this.tip.VerticalOffset = e.GetPosition(null).Y - 220;

                mainContent.Margin = new Thickness(10, 10, 10, 0);
            }
            else if (screenRight < 0 && screenTop < 0)
            {
                this.imageBrushOne.ImageSource = new BitmapImage(new Uri("Img/tipWindowThree.png", UriKind.Relative));
                this.tip.HorizontalOffset = e.GetPosition(null).X - 275;
                this.tip.VerticalOffset = e.GetPosition(null).Y;

                mainContent.Margin = new Thickness(10, 50, 10, 0);
            }
            else
            {
                this.imageBrushOne.ImageSource = new BitmapImage(new Uri("Img/tipWindowOne.png", UriKind.Relative));
                this.tip.HorizontalOffset = e.GetPosition(null).X - 200;
                this.tip.VerticalOffset = e.GetPosition(null).Y - 220;

                mainContent.Margin = new Thickness(10, 10, 10, 0);
            }

 

        }

        #endregion


        private void tip_MouseMove(object sender, MouseEventArgs e)
        {
            this.tip.IsOpen = true;
        }

    }
}

 

基于Spring Boot搭建的一个多功能在线学习系统的实现细节。系统分为管理员和用户两个主要模块。管理员负责视频、文件和文章资料的管理以及系统运营维护;用户则可以进行视频播放、资料下载、参与学习论坛并享受个性化学习服务。文中重点探讨了文件下载的安全性和性能优化(如使用Resource对象避免内存溢出),积分排行榜的高效实现(采用Redis Sorted Set结构),敏感词过滤机制(利用DFA算法构建内存过滤树)以及视频播放的浏览器兼容性解决方案(通过FFmpeg调整MOOV原子位置)。此外,还提到了权限管理方面自定义动态加载器的应用,提高了系统的灵活性和易用性。 适合人群:对Spring Boot有一定了解,希望深入理解其实际应用的技术人员,尤其是从事在线教育平台开发的相关从业者。 使用场景及目标:适用于需要快速搭建稳定高效的在线学习平台的企业或团队。目标在于提供一套完整的解决方案,涵盖从资源管理到用户体验优化等多个方面,帮助开发者更好地理解和掌握Spring Boot框架的实际运用技巧。 其他说明:文中不仅提供了具体的代码示例和技术思路,还分享了许多实践经验教训,对于提高项目质量有着重要的指导意义。同时强调了安全性、性能优化等方面的重要性,确保系统能够应对大规模用户的并发访问需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值