WPf 带滚动条WrapPanel 自动换行 和控件右键菜单
原文:WPf 带滚动条WrapPanel 自动换行 和控件右键菜单
技能点包括 WPf 样式的引用 数据的验证和绑定 比较适合初学者
前台:
-
<Window.Resources>
-
<local:PathToSource x:Key="n2"/>
-
<Style x:Key="{x:Type ContextMenu}" TargetType="{x:Type ContextMenu}">
-
<Setter Property="OverridesDefaultStyle" Value="True"/>
-
<Setter Property="SnapsToDevicePixels" Value="True"/>
-
<Setter Property="Template">
-
<Setter.Value>
-
<ControlTemplate TargetType="{x:Type ContextMenu}">
-
<Border Background="#CD222120" CornerRadius="7, 7, 8, 8" BorderBrush="DarkGray" BorderThickness="2" Opacity="0.96">
-
<StackPanel ClipToBounds="True" Orientation="Vertical" IsItemsHost="True" Margin="5,4,5,4"/>
-
</Border>
-
</ControlTemplate>
-
</Setter.Value>
-
</Setter>
-
</Style>
-
<ControlTemplate x:Key="{x:Static MenuItem.TopLevelItemTemplateKey}" TargetType="{x:Type MenuItem}">
-
<Border Name="Border" >
-
<Grid>
-
<ContentPresenter Margin="6,3,6,3" ContentSource="Header" RecognizesAccessKey="True" />
-
</Grid>
-
</Border>
-
</ControlTemplate>
-
-
<DataTemplate x:Key="Wrapitem">
-
<Grid Height="86" Width="86" >
-
<Grid.ContextMenu>
-
<ContextMenu Name="cm" StaysOpen="true">
-
<MenuItem Header="update"/>
-
<MenuItem Header="Save"/>
-
<MenuItem Header="SaveAs"/>
-
</ContextMenu>
-
-
</Grid.ContextMenu>
-
<Image Margin="8,8,8,24" Source="{Binding Path=Url,Converter={StaticResource n2}}"/>
-
<Label Content="{Binding Path=Text}" Height="22" Width="45" VerticalAlignment="Bottom"/>
-
</Grid>
-
-
</DataTemplate>
-
</Window.Resources>
-
<Grid>
-
<ListBox x:Name="list" Margin="124,63,109,44" ScrollViewer.HorizontalScrollBarVisibility="Hidden" ItemTemplate="{StaticResource Wrapitem}">
-
<ListBox.Resources>
-
<Style TargetType="ListBoxItem">
-
-
<Style.Resources>
-
-
<SolidColorBrush x:Key="{x:Static SystemColors.HighlightBrushKey}" Color="#FFA1A1A1"/>
-
</Style.Resources>
-
</Style>
-
</ListBox.Resources>
-
-
-
<!--<ListBox.ItemsPanel >
-
<ItemsPanelTemplate>
-
<WrapPanel Orientation="Horizontal" IsItemsHost="True"/>
-
</ItemsPanelTemplate>
-
-
</ListBox.ItemsPanel>-->
-
<ListBox.Template>
-
<ControlTemplate TargetType="{x:Type ListBox}">
-
<ScrollViewer HorizontalScrollBarVisibility="Disabled" VerticalScrollBarVisibility="Auto">
-
<WrapPanel Orientation="Horizontal" IsItemsHost="True" ScrollViewer.CanContentScroll="True"/>
-
</ScrollViewer>
-
</ControlTemplate>
-
</ListBox.Template>
-
</ListBox>
-
-
-
-
</Grid>
-
</Window>
后台:
-
/// <summary>
-
/// MainWindow.xaml 的交互逻辑
-
/// </summary>
-
public partial class MainWindow : Window
-
{
-
public MainWindow()
-
{
-
InitializeComponent();
-
load();
-
}
-
-
public void load()
-
{
-
ObservableCollection<Mean> ListMean = new ObservableCollection<Mean>()
-
{
-
new Mean(){Text="001",Url="i"},
-
new Mean(){Text="002",Url="i"},
-
new Mean(){Text="003",Url="ii"},
-
new Mean(){Text="004",Url="i"},
-
new Mean(){Text="005",Url="i"},
-
new Mean(){Text="006",Url="ii"},
-
new Mean(){Text="007",Url="i"},
-
new Mean(){Text="008",Url="i"},
-
new Mean(){Text="009",Url="i"},
-
new Mean(){Text="010",Url="i"},
-
new Mean(){Text="011",Url="ii"},
-
new Mean(){Text="012",Url="i"},
-
new Mean(){Text="013",Url="i"},
-
new Mean(){Text="014",Url="i"},
-
new Mean(){Text="015",Url="i"},
-
new Mean(){Text="016",Url="i"},
-
new Mean(){Text="017",Url="i"}
-
};
-
list.ItemsSource = ListMean;
-
}
-
}
-
public class Mean : INotifyPropertyChanged
-
{
-
private string text;
-
-
public string Text
-
{
-
get { return text; }
-
set { text = value; OnPropertyChanged("Text"); }
-
}
-
private string url;
-
-
public string Url
-
{
-
get { return url; }
-
set { url = value; OnPropertyChanged("Url"); }
-
}
-
-
public event PropertyChangedEventHandler PropertyChanged;
-
-
public void OnPropertyChanged(string propertyName)
-
{
-
-
if (PropertyChanged != null)
-
{
-
-
PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
-
-
}
-
-
}
-
}
-
public class PathToSource:IValueConverter
-
{
-
public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
-
{
-
-
string url = string.Format(@"/Images/{0}.jpg", (string)value=="i"?"i":"ii");
-
return new BitmapImage(new Uri(url,UriKind.Relative));
-
}
-
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
-
{
-
throw new NotImplementedException();
-
}
-
}
WPf 带滚动条WrapPanel 自动换行 和控件右键菜单的更多相关文章
- MFC小型工具通用界面框架CLIST控件+右键菜单功能
MFC-小型工具通用界面框架 0x1 场景 由于工作需要我会写代码开发工具给客户或者同事用.代码都能实现,但写个黑乎乎的命令行工具给别人用确实显得不够专业,用别人写好的成型工具又担心有后门. 所以掌握 ...
- FineUI Grid控件右键菜单的实现
FineUI官方Demo上一直没有Grid右键菜单的实现,其实从4.1.x的版本开始,允许添加自定义的事件监听(Listeners),所以要实现这个功能已经相当容易了. ExtJs右键菜单有很多种,对 ...
- win32 listctrl控件右键菜单的实现
HMENU Menu_list,Menu_all; POINT point; HINSTANCE hInstance;//下面代码放到BOOL WINAPI DialogProc下 case WM_C ...
- WPF中不规则窗体与WebBrowser控件的兼容问题解决办法
原文:WPF中不规则窗体与WebBrowser控件的兼容问题解决办法 引言 这几天受委托开发一个网络电视项目,要求初步先使用内嵌网页形式实现视频播放和选单,以后再考虑将网页中的所有功能整合进桌面程序. ...
- WPF自定义控件(五)の用户控件(完结)
用户控件,WPF中是继承自UserControl的控件,我们可以在里面融合我们的业务逻辑. 示例:(一个厌恶选择的用户控件) 后端: using iMicClassBase; using iMicCl ...
- Git使用总结 Asp.net生命周期与Http协议 托管代码与非托管代码的区别 通过IEnumerable接口遍历数据 依赖注入与控制反转 C#多线程——优先级 AutoFac容器初步 C#特性详解 C#特性详解 WPF 可触摸移动的ScrollViewer控件 .NET(C#)能开发出什么样的APP?盘点那些通过Smobiler开发的移动应用
一,原理 首先,我们要明白Git是什么,它是一个管理工具或软件,用来管理什么的呢?当然是在软件开发过程中管理软件或者文件的不同版本的工具,一些作家也可以用这个管理自己创作的文本文件,由Linus开发的 ...
- 封装:WPF中可以绑定的BindPassWord控件
原文:封装:WPF中可以绑定的BindPassWord控件 一.目的:本身自带的PassWord不支持绑定 二.Xaml部分 <UserControl x:Class="HeBianG ...
- WPF布局之让你的控件随着窗口等比放大缩小,适应多分辨率满屏填充应用
一直以来,我们设计windows应用程序,都是将控件的尺寸定好,无论窗体大小怎么变,都不会改变,这样的设计对于一般的应用程序来说是没有问题的,但是对于一些比较特殊的应用,比如有背景图片的,需要铺面整个 ...
- WPF自定义控件与样式(9)-树控件TreeView与菜单Menu-ContextMenu
一.前言 申明:WPF自定义控件与样式是一个系列文章,前后是有些关联的,但大多是按照由简到繁的顺序逐步发布的等,若有不明白的地方可以参考本系列前面的文章,文末附有部分文章链接. 本文主要内容: 菜单M ...
随机推荐
- Dynamics 365需要的最小的权限用来更改用户的业务部门和角色
我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...
- bayaim_Centos7.6_mysql源码5.7-多my.cnf_20190424.txt
用户名/密码mysql/mysql 一.安装mysql: 位置位于 /data/mysql 如果遇到依赖,无法删除,使用 rpm -e --nodeps <包的名字> 不检查依赖,直接删除 ...
- linux系统的特殊符号
符号 作用 示例 # 注释符号,井号后的内容不会执行 echo #WORD ~ 当前用户的家目录 cd ~ ; 命令顺序执行,前面执行成功与否对后面没影响 COMMAND1 ; COMMAND2 &a ...
- 初级模拟电路:4-1 BJT交流分析概述
回到目录 BJT晶体管的交流分析(也叫小信号分析)是模拟电路中的一个难点,也可以说是模电中的一个分水岭.如果你能够把BJT交流分析的原理全都搞懂,那之后的学习就是一马平川了.后面的大部分内容,诸如:场 ...
- rpm包安装java jar开机自启
1.安装jdk: rpm -ivh jdk-8u201-linux-x64.rpm 2.配置jdk路径 打开/etc/profile增加以下内容: export JAVA_HOME=/usr/java ...
- 31.Java基础_日期/日期格式/日历类
Date类 Date对象构造方法 Date对象常用方法 import java.util.*; public class test { public static void main(String[] ...
- Objective-C中 #include 和 #import 的区别
由于 Objective-C 兼容 C 语言,所以导入文件时, 可以使用 #include,也可以使用 #import (Objective-C 新增的) 如: #include <stdio. ...
- ceph安装笔记
配置源 ceph版本为luminous [root@ceph-node1 ~]# yum install -y https://dl.fedoraproject.org/pub/epel/epel-r ...
- 《移动WEB前端高级开发实践@www.java1234.com.pdf》——2
5.3 作用域.闭包和this let 声明的变量只存在于其所在的代码块中 由于 JS 是基于词法(静态)作用域的语言,词法作用域的含义是在函数定义时就确定了作用域,而不是函数执行时再确定 calcu ...
- Ubuntu16.04 GTX750安装CUDA9.0,Pytorch,Anaconda教程
Ubuntu16 GTX750安装CUDA9.0,Pytorch,Anaconda教程 安装前警告 不要使用Ubuntu18! 不要使用Ubuntu18! 不要使用Ubuntu18! 务必重装成Ubu ...