Pular para o conteúdo principal

Clique direito em Datagrid (Silverlight)

Uma das coisas mais frustrantes no Silverlight com toda certeza é ver aquela "caixinha" com informações quando clicamos com o botão direito, porque quando executamos essa ação estamos, na maioria das vezes, buscando novas funcionalidades ou informações que dizem respeito ao que estamos vendo naquele momento, mas esse comportamento original pode ser alterado para nossa alegria.

No exemplo a seguir iremos apresentar um menu de contexto codificando o evento "MouseRightButtonDown" do DataGrid:

     
    
        xmlns:grid="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data"
        xmlns:toolkit="http://schemas.microsoft.com/winfx/2006/xaml/presentation/toolkit" >

        < grid :DataGrid MouseRightButtonDown="_grid_MouseRightButtonDown" >
            
            < toolkit:ContextMenuService.ContextMenu >
                < toolkit:ContextMenu>
                    < toolkit:MenuItem Header="Action!" / >
                < / toolkit:ContextMenu >
            < / toolkit:ContextMenuService.ContextMenu >
        < / grid:DataGrid >
    < / UserControl >


    // Classe C#
    private void _grid_MouseRightButtonDown(object sender, MouseButtonEventArgs e)
    {
        IEnumerable elementsUnderMouse =
            VisualTreeHelper
                .FindElementsInHostCoordinates(e.GetPosition(null), this);
        DataGridRow row =
            elementsUnderMouse
                .Where(uie => uie is DataGridRow)
                .Cast()
                .FirstOrDefault();
        if (row != null)
            _grid.SelectedItem = row.DataContext;
    }



Fonte:
msdn
Silverlight

Comentários

Mais visitadas

Iniciar e Parar Serviços do Windows (Delphi)

Em certas ocasiões nos deparamos com a necessidade de manipular determinadas atividades do SO, como iniciar ou parar um banco de dados, ou qualquer outro serviço que esteja funcionando no momento. Segue abaixo um código que encontrei na Internet para tal finalidade (não me recordo à fonte, assim que eu a encontrar colocarei). Iniciar Serviço: uses WinSvc; // // start service // // return TRUE if successful // // sMachine: //   machine name, ie: \SERVER //   empty = local machine // // sService //   service name, ie: Alerter // function ServiceStart(   sMachine,   sService : string ) : boolean; var   //   // service control   // manager handle   schm,   //   // service handle   schs   : SC_Handle;   //   // service status   ss     : TServiceStatus;   //   // te...

Manipular arquivos com PL/SQL (Oracle)

O bom e velho arquivo, é impressionante como lidamos com seus vários tipos durante todos os dias, bom hoje vamos mostrar um jeito simples de se escrever e ler arquivos apenas com a codificação nativa do Oracle. A primeira coisa a fazer é criar um diretório válido configurado no Oracle, e permissões de acesso a esse diretório para o usuário de banco onde faremos o exemplo, sendo assim suponhamos que nosso usuário de banco se chame programero, e nosso diretório real esteja em c:\programero, então logado como SYSTEM devemos executar os seguintes comandos: 1: -- cria diretorio 2: create or replace directory DIR_PROGRAMERO as ' C:\PROGRAMERO '; 3: -- concede permissão de escrita e leitura para nosso usuário 4: grant read , write on directory DIR_PROGRAMERO to PROGRAMERO; Para escrever, basicamente precisamos apenas saber onde esse arquivo ficará, no nosso caso no diretório criado acima, segue o código de escrita: 1: declare 2: -- nosso handler 3: v_a...

Criando uma Aplicação CRUD com Flask, PostgreSQL e Docker

Criando uma Aplicação CRUD com Flask, PostgreSQL e Docker Neste guia, vamos criar uma aplicação básica que acessa um banco de dados PostgreSQL e realiza operações CRUD (Create, Read, Update, Delete). Vamos usar Flask e executar tudo com Docker. Sem estilos ou extras, apenas o essencial. Estrutura do Projeto crud-app/ |-- app/ | |-- app.py | |-- templates/ | | |-- index.html | | |-- edit.html |-- Dockerfile |-- requirements.txt |-- docker-compose.yml Passo 1: Dependências Crie um arquivo requirements.txt com as seguintes linhas: Flask==2.2.2 Flask-SQLAlchemy==3.0.2 psycopg2-binary==2.9.3 Werkzeug==2.2.2 Passo 2: Aplicação Flask Arquivo app/app.py : from flask import Flask, render_template, request, redirect, url_for from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) # Configuração do banco de dados app.config['SQLALCHEMY_DATABASE_URI'] = 'postgresql://user:password@db:5432/crud_db' app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False db...