本文主要让menuflyout出现在我们右击位置。
我们一般使用的menuflyout写在前台,写在button里面,但是可能我们的menuflyout显示的位置和我们想要的不一样。
通过使用后台写showat的方法,我们可以通过e.getposition获得鼠标点击位置,需要对函数传入相对的元素,这个元素一般可以用我们点击使用的元素,也可以使用我们的最外层grid,这样我们就可以获得了鼠标位置,也就可以显示我们的menuflyout在点击位置。
我们建一个listview,然后绑定后台,在我们listview要右击显示我们的浮出,要求我们的浮出在我们点击位置。
menuflyout可以在后台写,当然写在前台也可以。
我们这写在后台,我们可以选择placement 显示在我们元素的位置,但这不是我们鼠标点击的位置,要显示我们鼠标点击的位置,其实也很简单。我们可以从e.getposition(sender as uielement)获得鼠标位置,把这个给menuflyout我们的浮出显示在我们鼠标点击位置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<listview itemssource= "{x:bind view.str}" >
<listview.itemcontainerstyle>
<style targettype= "listviewitem" >
<setter property= "horizontalcontentalignment"
value= "stretch" />
<setter property= "verticalcontentalignment" value= "center" ></setter>
</style>
</listview.itemcontainerstyle>
<listview.itemtemplate>
<datatemplate>
<grid background= "#ffda2a5c" righttapped= "gridcolection_onrighttapped" >
<textblock text= "{binding}" ></textblock>
</grid>
</datatemplate>
</listview.itemtemplate>
</listview>
|
后台写
1
2
3
4
5
6
7
8
9
10
11
12
13
|
private void gridcolection_onrighttapped( object sender, righttappedroutedeventargs e)
{
menuflyout myflyout = new menuflyout();
menuflyoutitem firstitem = new menuflyoutitem { text = "oneit" };
menuflyoutitem seconditem = new menuflyoutitem { text = "twoit" };
myflyout.items.add(firstitem);
myflyout.items.add(seconditem);
//if you only want to show in left or buttom
//myflyout.placement = flyoutplacementmode.left;
frameworkelement senderelement = sender as frameworkelement;
//the code can show the flyout in your mouse click
myflyout.showat(sender as uielement, e.getposition(sender as uielement));
}
|
以上所述是小编给大家介绍的c#实现win10 uwp 右击浮出窗在点击位置,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://blog.csdn.net/lindexi_gd/article/details/52724410