TreeView的自定义右键菜单(半原创)

http://www.cnblogs.com/liangjie/archive/2011/01/20/1940433.html

 

最近项目中有一个小小的需求,要求实现TreeView的自定义菜单,于是乎就收集资料,现将自己收集资料分享一下

1.示例

                                                                                              

                                      效果图

方法一 :利用oncontextmenu事件来实现

代码:

<html  >
<head runat="server">
    <title>xTreeView</title>
    <style type="text/css">
<!--
/*菜单样式*//*菜单项样式*/
.skin0{
position:absolute;
width:140px;
border:2px solid black;
background-color:menu;
font-family:Verdana;
line-height:20px;
cursor:default;
font-size:14px;
z-index:100;
visibility:hidden;
}
.menuitems
{
padding-left:10px;
padding-right:10px;
font-family:Verdana;
font-size:12px;
color:black;
}
-->
</style>

</head>
<body>
<form id="form1" runat="server" >
               <asp:Panel ID="Panel1" runat="server" Height="50px" Width="176px" >
               <asp:TreeView ID="TreeView1" runat="server" BackColor="#FFFFC0"  Height="180px" Width="172px">
                <Nodes>
                    <asp:TreeNode Text="Root" Value="sroot">
                        <asp:TreeNode  Text="Parent 1" Value="sParent 1">
                            <asp:TreeNode Text="<b id='b1' οncοntextmenu='return showmenuie(event)'  >this is a test</b>" Value=

                                                        "sLeaf 1" ></asp:TreeNode>
                            <asp:TreeNode Text="Leaf 2" Value="sLeaf 2"></asp:TreeNode>
                        </asp:TreeNode>
                        <asp:TreeNode Text="Parent 2" Value="sParent 2">
                            <asp:TreeNode Text="Leaf 1" Value="sLeaf 1"></asp:TreeNode>
                            <asp:TreeNode Text="Leaf 2" Value="sLeaf 2"></asp:TreeNode>
                        </asp:TreeNode>
                    </asp:TreeNode>
                </Nodes>
            </asp:TreeView>
        </asp:Panel>
        <div>
        <asp:Panel ID="Panel2"  runat="server" display:none BorderColor="Black" CssClass="skin0" onMouseover="highlightie(event)" onMouseout="lowlightie(event)" onClick="jumptoie(event)"  >
                <div class="menuitems"><asp:LinkButton ID="LinkButton1" runat="server"   CssClass="menuitems" >New Node</asp:LinkButton></div>
                <div class="menuitems"><asp:LinkButton ID="LinkButton2" runat="server"   CssClass="menuitems">Edit Node</asp:LinkButton></div>
                <hr />
                <div class="menuitems"><asp:LinkButton ID="LinkButton3" runat="server"   CssClass="menuitems">Delete Node</asp:LinkButton></div>
                <hr />
                <div class="menuitems"><asp:LinkButton ID="LinkButton4" runat="server"   CssClass="menuitems">FAQS</asp:LinkButton></div>
                <div class="menuitems"><asp:LinkButton ID="LinkButton5" runat="server"   CssClass="menuitems">Online Help</asp:LinkButton></div>
                <hr />
                <div class="menuitems"><asp:LinkButton ID="LinkButton6" runat="server"   CssClass="menuitems">Email Me</asp:LinkButton></div>
            </asp:Panel>
         </div>
    </form> 
 <script src="xtreeview.js"  type="text/javascript"></script>
</body>
</html>
相应的Js代码:

   // xtreeView JScript File

var ie=document.all&&document.getElementById
var ns=document.getElementById&&!document.all
if (ie||ns)
var menuobj=document.getElementById("Panel2")

//屏蔽浏览器右键菜单并显示自定义右键菜单
function showmenuie(e) {

//设置右键菜单的位置
var rightedge=ie? document.body.clientWidth-event.clientX : window.innerWidth-e.clientX
var bottomedge=ie? document.body.clientHeight-event.clientY : window.innerHeight-e.clientY
if (rightedge<menuobj.offsetWidth)
       menuobj.style.left=ie? document.body.scrollLeft+event.clientX-menuobj.offsetWidth : window.pageXOffset+e.clientX-menuobj.offsetWidth
else
       menuobj.style.left=ie? document.body.scrollLeft+event.clientX : window.pageXOffset+e.clientX
if (bottomedge<menuobj.offsetHeight)
       menuobj.style.top=ie? document.body.scrollTop+event.clientY-menuobj.offsetHeight : window.pageYOffset+e.clientY-menuobj.offsetHeight
else
       menuobj.style.top=ie? document.body.scrollTop+event.clientY : window.pageYOffset+e.clientY

 

//让菜单显示
menuobj.style.visibility="visible"

//屏蔽浏览器右键
return false
}

function hidemenuie(e) {
//让菜单隐藏
      menuobj.style.visibility="hidden"
}

//当鼠标旋停在菜单的某项时高亮显示
function highlightie(e){
     var firingobj=ie? event.srcElement : e.target
     if (firingobj.className=="menuitems"||ns&&firingobj.parentNode.className=="menuitems"){
                if (ns&&firingobj.parentNode.className=="menuitems")

                                {
                                   firingobj=firingobj.parentNode

                                 }

                firingobj.style.backgroundColor="highlight"

}
}

//当鼠标离开在菜单的某项时某项正常显示
function lowlightie(e){
    var firingobj=ie? event.srcElement : e.target
    if (firingobj.className=="menuitems"||ns&&firingobj.parentNode.className=="menuitems"){
                 if (ns&&firingobj.parentNode.className=="menuitems")
                        {

                           firingobj=firingobj.parentNode

                        }

                firingobj.style.backgroundColor=""
                window.status=''
  }
}

function jumptoie(e){
    var firingobj=ie? event.srcElement : e.target
    if (firingobj.className=="menuitems"||ns&&firingobj.parentNode.className=="menuitems"){
             if (ns&&firingobj.parentNode.className=="menuitems")
                    var firingobj2=firingobj.parentNode

    }
}

if (ie||ns){
     menuobj.style.display=''
     document.οnclick=hidemenuie

}

注意:

    1.红色部分不能缺少return(少了return哪怕你在body里加上οncοntextmenu=“return false”也不行):只要有oncontextmenu事件就会有浏览器右键菜单,除非你

           事件返回值为false

           

方法二利用onmouseup或者onmousedown来实现

只要在以上代码中去掉οncοntextmenu='return showmenuie(event)'加上onmousedup='test(event)'或者οnmοusedοwn='test(event)'并加上

οncοntextmenu="return false"即可。其中test(加到原JS代码中)定义如下:

function test(event) {
    if (event.button == 2) {
        showmenuie(event);
    }
}

至于其中的细节,可以去查看其他资料。两种方法原理一样。           

原示例来源:http://www.cnblogs.com/blodfox777/archive/2008/08/29/1279675.html

您好!对于在Qt中使用TreeView控件,并添加右键菜单的需求,您可以按照以下步骤进行操作: 1. 创建TreeView控件:在Qt中,您可以使用QTreeView类创建一个TreeView控件。例如,在您的窗口类中添加以下代码: ```cpp QTreeView *treeView = new QTreeView(this); ``` 2. 创建右键菜单:使用QMenu类创建一个右键菜单。例如,在您的窗口类的构造函数中添加以下代码: ```cpp QMenu *menu = new QMenu(this); menu->addAction("Action 1"); menu->addAction("Action 2"); // 添加更多的菜单项... ``` 3. 关联右键菜单TreeView控件:通过在TreeView控件的contextMenuPolicy属性中设置Qt::CustomContextMenu,启用自定义上下文菜单。然后,重写TreeView控件的contextMenuEvent()方法,以显示自定义菜单。在您的窗口类中添加以下代码: ```cpp treeView->setContextMenuPolicy(Qt::CustomContextMenu); connect(treeView, &QTreeView::customContextMenuRequested, this, [=](const QPoint &pos) { QContextMenuEvent event(QContextMenuEvent::Mouse, pos); treeView->contextMenuEvent(&event); }); ``` 4. 在contextMenuEvent()方法中显示右键菜单:重写TreeView控件的contextMenuEvent()方法,并在其中显示自定义菜单。在您的窗口类中添加以下代码: ```cpp void YourWindowClass::contextMenuEvent(QContextMenuEvent *event) { QPoint pos = event->pos(); QModelIndex index = treeView->indexAt(pos); if (index.isValid()) { QMenu *menu = new QMenu(this); menu->addAction("Action 1"); menu->addAction("Action 2"); // 添加更多的菜单项... menu->exec(treeView->viewport()->mapToGlobal(pos)); } } ``` 这样,您就可以在TreeView控件上右键单击,并显示自定义右键菜单了。根据您的需求,您可以根据TreeView中的选定项的位置,添加相应的操作。 希望对您有所帮助!如果有任何进一步的问题,请随时提问。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值