Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - Xephiro

#1
Sí, hice un hola mundo. El problema es que puedo ejecutar la aplicación desde dentro del mismo Visual Studio, pero cuando trato de ejecutar la aplicación abriendo directamente el ejecutable compilado, esta no corre.

Esto pasa con todos los proyectos que tengo creados, incluso con algunos que antiguamente sí me funcionaban.
#2
Me encuentro con el siguiente problema en Visual Studio, cuando compilo una aplicación puedo ejecutarla sólo desde el modo de depuración dentro de visual studio, pero al momento de ser compilada y ejecutada fuera de este, el programa no correo y tampoco arroja algún error.

¿alguna idea de que puedo hacer?. Ya he probado reinstalando por completo Visual Studio 2 veces y el error persiste.
#3
Cita de: kub0x en 24 Abril 2015, 19:00 PM
Buenas,

¿podrías aportar el mensaje de error obtenido al recibir la excepción? Por lo que veo cada thread recibe un identificador distinto asi que no veo problema alguno en la creación de los archivos ya que todos tendrían nombres distintos.

Por cierto, tienes que cerrar el stream(FileStream) después de trabajar con él. Aporta más código y te ayudaremos.

Saludos.

El mensaje que arroja es el siguiente:

Citar
"El proceso no puede obtener acceso al archivo 'D:\\temp_30.tmp' porque está siendo utilizado en otro proceso."

Esto ya me resulta extraño, ya que aun pasando indices a cada hilo, por algún motivo tratan de acceder a un mismo varios hilos.
#4
Estimados,

Tengo un problema para crear archivos de forma paralela.

tengo 5 hilos para crear N archivos (siempre sobre 10), pero por algún motivo no funciona como creo.

Dejo parte del código para explicarme mejor:

Primero creao los hilos y les doy la función con sus parametros a ejecutar (primer for) y luego los ejecuto cada uno de ellos (segundo for)

Código (csharp) [Seleccionar]
Thread[] ThreadsPool = new Thread[inter];
           for (int i = 0; i < inter; i++)
           {
               ThreadsPool[i] = new Thread(() => Func1(start, end, i));
           }

           for (int i = 0; i < inter; i++)
           {
               ThreadsPool[i].Start();
           }


A continuación muestro parte de la Func1

Código (csharp) [Seleccionar]

private static void Func1(long initial, long final, int index)
       {
           try
           {
               semaphore.WaitOne();
               ....

               stream = File.Create("D:/temp_"+i+".tmp"); // LINEA CON PROBLEMAS
               do
               {
                   ....
               }
               while (...);
           }
           finally
           {
               semaphore.Release();
           }
       }


Estoy utilizando un semaforo de capacidad 5, pero por algún motivo cuando ejecuto los threads, siempre tratan de crear el mismo archivo, por lo que el programa cae ya que mas de un hilo trata de sobre escribir al mismo tiempo.

Intente con un lock justo en ese tramo, pero el error se mantiene.

¿Alguna idea de que puede ser? ya que si comento la línea para crear el archivo el resto del código que tengo se ejecuta sin ningun problema.
#5
Cita de: MCKSys Argentina en 16 Agosto 2014, 04:30 AM
Bueno, también podrías usar un driver, pero nunca he hecho uno.

Lo poco que conozco sobre estos temas, en el campo de drivers, es vJoy.

No es lo que quieres, pero quizás pueda guiarte hacia lo que necesitas...  :P

Saludos!

Ok, se agradece la información, le daré un vistazo.
#6
Si, he utilizado de forma muy similar a los ejemplos que dejaste.

Lo que puedo hacer de momento es
        - Lograr identificar que realmente se encuentra conectado el teclado a examinar.
        - Obtener tu handle
        - Ver la información enviada desde el teclado.

Pero no puedo lograr alterar o interceptar de alguna forma lo que envía este teclado sin alterar los demas teclados que se encuentren conectados.
#7
Hola a todos,

Me encuentro hace un par de días estancado con un tema que estoy tratando de realizar.

Estoy intentando Hookear un teclado (existen 2 teclados conectados en el equipo), lo que busco es Hookear y poder detener o alterar las teclas pulsadas por uno de estos dos teclados. El estoy utilizando LowLevelKeyboardProc pero solo he logrado detener y modificar lo que se escribe para todos los teclados existentes por igual.

Por otro lado he intentado utilizando GetRawInputDeviceList + GetRawInputData logro obtener el Handle del teclado que me interesa alterar y solo ver la información enviada por este teclado. No puedo ni modificarla ni detenerla.

¿Existe alguna forma de lograr lo que busco?
#8
Hola, tengo la siguiente consulta

¿Es posible obtener los bytes por ejemplo de un Icono almacenado en un archivo de recursos?

:-[


Ya conseguí una solución... :D
#9
Para aquellos que necesiten algo similar dejo el código (No es nada estético ni complicado.)

Código (cpp) [Seleccionar]
#include <windows.h>
#include <iostream>
#include <cstring>

using namespace std;

LRESULT CALLBACK WindowProcedure (HWND, UINT, WPARAM, LPARAM);

char szClassName[ ] = "WindowsApp";

int main (int count, char* args[])
{
   bool flag = true;

   ...........
   
   if(flag)
   {
       HWND hwnd;
       MSG messages;
       WNDCLASSEX wincl;
   
       /* The Window structure */
       wincl.hInstance = NULL;
       wincl.lpszClassName = szClassName;
       wincl.lpfnWndProc = WindowProcedure;
       wincl.style = CS_DBLCLKS;
       wincl.cbSize = sizeof (WNDCLASSEX);
       wincl.hIcon = LoadIcon (NULL, IDI_APPLICATION);
       wincl.hIconSm = LoadIcon (NULL, IDI_APPLICATION);
       wincl.hCursor = LoadCursor (NULL, IDC_ARROW);
       wincl.lpszMenuName = NULL;
       wincl.cbClsExtra = 0;
       wincl.cbWndExtra = 0;                      
       wincl.hbrBackground = (HBRUSH) COLOR_BACKGROUND;
   
       if (!RegisterClassEx (&wincl))
           return 0;
   
       hwnd = CreateWindowEx (
              0,                   /* Extended possibilites for variation */
              szClassName,         /* Classname */
              "Windows App",       /* Title Text */
              WS_OVERLAPPEDWINDOW, /* default window */
              CW_USEDEFAULT,       /* Windows decides the position */
              CW_USEDEFAULT,       /* where the window ends up on the screen */
              544,                 /* The programs width */
              375,                 /* and height in pixels */
              HWND_DESKTOP,
              NULL,
              NULL,
              NULL
              );
   
       ShowWindow (hwnd, 1);
   
       while (GetMessage (&messages, NULL, 0, 0))
       {
           TranslateMessage(&messages);
           DispatchMessage(&messages);
       }
   }
   else
   {
       cout<<":D"<<endl;
       cin.get();
   }
   
   return 0;
}

LRESULT CALLBACK WindowProcedure (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
{
   switch (message)
   {
       case WM_DESTROY:
           PostQuitMessage (0);
           break;
       default:
           return DefWindowProc (hwnd, message, wParam, lParam);
   }

   return 0;
}



PD: Es obvio que mas estético y cómodo se vería separar toda la creación de la ventana en un método aparte :D

Saludos....
#10
Gracias, le daré una mirada a ver si logro sacar lo que estoy tratando de hacer..