BOOL CreateProcess(
  LPCTSTR lpApplicationName,                 // name of executable module
  LPTSTR lpCommandLine,                      // command line string
  LPSECURITY_ATTRIBUTES lpProcessAttributes, // SD
  LPSECURITY_ATTRIBUTES lpThreadAttributes,  // SD
  BOOL bInheritHandles,                      // handle inheritance option
  DWORD dwCreationFlags,                     // creation flags
  LPVOID lpEnvironment,                      // new environment block
  LPCTSTR lpCurrentDirectory,                // current directory name
  LPSTARTUPINFO lpStartupInfo,               // startup information
  LPPROCESS_INFORMATION lpProcessInformation // process information
);void main( VOID )
{
    STARTUPINFO si;
    PROCESS_INFORMATION pi;    ZeroMemory( &si, sizeof(si) );
    si.cb = sizeof(si);
    ZeroMemory( &pi, sizeof(pi) );    // Start the child process. 
    if( !CreateProcess( NULL, // No module name (use command line). 
        "MyChildProcess", // Command line. 
        NULL,             // Process handle not inheritable. 
        NULL,             // Thread handle not inheritable. 
        FALSE,            // Set handle inheritance to FALSE. 
        0,                // No creation flags. 
        NULL,             // Use parent's environment block. 
        NULL,             // Use parent's starting directory. 
        &si,              // Pointer to STARTUPINFO structure.
        &pi )             // Pointer to PROCESS_INFORMATION structure.
    ) 
    {
        ErrorExit( "CreateProcess failed." );
    }    // Wait until child process exits.
    WaitForSingleObject( pi.hProcess, INFINITE );    // Close process and thread handles. 
    CloseHandle( pi.hProcess );
    CloseHandle( pi.hThread );
}如何把那个程序放到一个 窗口中去呢?

解决方案 »

  1.   

    关键参数请详细说明谢谢了
     STARTUPINFO si;
        PROCESS_INFORMATION pi;如何通过pi来设置窗口的大小(例子最好)
      

  2.   

     STARTUPINFO si
    si.dwX; 
     si.dwY; 
     si.dwXSize; 
     si.dwYSize;这四个参数用来设置窗口。控制台窗口也可以由它设置。
      

  3.   

    to GR(战役)  多谢大侠有意帮助,但是我 设置为什么没有效果啊,
    条件
    1.我的那个应用程序是全屏的(最顶)
    我也用了 
    si.dwX; 
     si.dwY; 
     si.dwXSize; 
     si.dwYSize;
    这些参数时,是根据 si.dwFlags 的值来分别测试的,
    但不成功:( ,是否我有什么地方遗漏掉了(显示时还是以全屏的形式显示)希望你能给个具体点的说明我(谢谢了)
      

  4.   

    楼上的朋友首先非常感谢你对我支持.....
    请问 我如何把一个已经写好了的exe文件合到 我要写的一个新的exe;里呢~~?
      

  5.   

    本文将介绍一个文件捆绑器的详细编写过程,编译环境:WIN2K+VC6。
    先假设我们要把 test1.exe和test2.exe这两个文件捆绑成target.exe这一个文件,然后在运行target.exe的时候实现同时运行test1.exe和test2.exe。普及一个知识,PE格式的文件只要不修改文件头和文件中间的内容,而只是在文件末尾添加数据,那么这个PE文件可以正常执行。你可以试一试在命令行方式下执行
    copy test1.exe+test2.exe,命令执行完成后,test2.exe被添加到test1.exe文件尾,执行合并后的test1.exe虽然正常,但是test2.exe得不到执行。OK,这就是我们今天要解决的问题。我的想法是这样的。把三个文件捆绑在一起,捆绑后target.exe实际包含三个文件,其中aaa.exe是我们自己写的程序,test1.exe和test2.exe是我们要捆绑的程序。
    结构如下----------------------------
    |aaa.exe|test1.exe|test2.exe|
    -----------------------------整个文件就叫target.exe,如果结构如上所示,那么我们执行target.exe的时候实际上只有aaa.exe才会得到执行,这里的aaa.exe是我们自己写的,我们就让aaa.exe多做点事,他要做的事就是:1、把test2.exe读出来另存为c:\test2.exe,把test1.exe的内容读出来另存为c:\test1.exe。2、调用CreateProcess来创建两个新进程运行test1.exe和test2.exe。3、调用ExitProcess结束自身的进程。
    这样一来我们的目的就达到了。同时为了隐蔽起见,我们可以把aaa.exe的窗口界面不显示出来。但是又有一个问题,读取的时候怎样才能分辨出哪一段数据是test1.exe,哪一段数据是test2.exe?那我们就再想办法把上面的结构再扩充一下。---------------------------------------
    |aaa.exe|test1.exe|test2.exe|len2|len1|
    ---------------------------------------在文件最后面再加两段数据,分别用来存放test1.exe的文件长度和test2.exe的文件长度。并且固定len2和len1为30字节的长度。这样在aaa.exe得到执行的时候先后面的两个30字节内容,内容就是两个文件的长度,再根据这两个长度就可以准确读取到test1.exe和test1.exe的内容。看看aaa.exe程序的关键代码:    CFile fSource(_pgmptr,CFile::modeRead | CFile::modeNoTruncate); //得到target.exe的文件长度
        int iSourceLength = fSource.GetLength();
        fSource.Seek(iSourceLength-60,CFile::begin);//移动文件指针到第test2.exe文件的末尾    char buffer[40];
        ZeroMemory(buffer,40);
        fSource.Read(buffer,30);//读取第len2的内容,也就是test2.exe的长度    int iTargetLength = atoi(buffer);
        fSource.Seek(iSourceLength-iTargetLength-60,CFile::begin);//移动文件指针到test2.exe文件的开头    CFile fTarget("c:\\test2.exe",CFile::modeCreate | CFile::modeWrite | CFile::modeNoTruncate);//创建一个新文件为c:\\test2.exe    char *pBuffer = new char[iTargetLength];//分配缓冲区
        ZeroMemory(pBuffer,iTargetLength);
        fSource.Read(pBuffer,iTargetLength);//将第test2.exe文件读到缓冲区
        fTarget.Write(pBuffer,iTargetLength);//将缓冲区内容写入c:\test2.exe
        delete pBuffer;好了,现在test2.exe文件已经读出来了,接下来就是要读test1.exe的内容,过程大同小异
        fSource.Seek(iSourceLength-30,CFile::begin);//将文件指针移动到len1的开头
        ZeroMemory(buffer,40);
        fSource.Read(buffer,30);//读取len1的内容,len1的内容是test1.exe文件的长度
        int filelen = atoi(buffer);
        fSource.Seek(iSourceLength-60-filelen-iTargetLength,CFile::begin);//将文件指针移动到test1.exe文件头
        fTarget.Open("c:\\test2.exe",CFile::modeCreate | CFile::modeWrite | CFile::modeNoTruncate);    pBuffer = new char[filelen];
        ZeroMemory(pBuffer,filelen);    fSource.Read(pBuffer,filelen);//将test1.exe文件读到缓冲区
        fTarget.Write(pBuffer,filelen);//将test1.exe文件写入c:\test1.exe
        
        delete pBuffer;
        fSource.Close();
        fTarget.Close();现在我们就用CreateProcess来运行创建两个新进程就可以运行c:\test1.exe和c:\test2.exe了。创建新进程的代码很简单我就不写了。这部分是写完了,但是我们捆绑文件的部分还没写完,重新新建一个基于对话框的程序。    CFile fSource("c:\\aaa.exe",CFile::modeReadWrite | CFile::modeNoTruncate); //就是上面我们写的aaa.exe
        fSource.SeekToEnd();//移动文件指针到文件尾    CFile fFirstFile(m_FirstFile,CFile::modeRead | CFile::modeNoTruncate); //这段代码是把test1.exe添加到aaa.exe尾部
        int ilen = fFirstFile.GetLength();
        int len = ilen;
        char *pBuffer = new char[ilen];
        ZeroMemory(pBuffer,ilen);
        fFirstFile.Read(pBuffer,ilen);
        fSource.Write(pBuffer,ilen);
        fFirstFile.Close();
        delete pBuffer;
        CFile fSecondFile(m_SecondFile,CFile::modeRead | CFile::modeNoTruncate); //这段代码是捆绑test2.exe的
        ilen = fSecondFile.GetLength();
        pBuffer = new char[ilen];
        ZeroMemory(pBuffer,ilen);
        fSecondFile.Read(pBuffer,ilen);
        fSource.Write(pBuffer,ilen);
        fSecondFile.Close();
        delete pBuffer;    char tempbuffer[30];//将test2.exe的长度转换成字符串,如果长度不够30就添加空格至30,再添加到文件尾部
        ZeroMemory(tempbuffer,30);
        itoa(ilen,tempbuffer,10);
        
        while (strlen(tempbuffer) < 30)
        {
            strcat(tempbuffer," ");
        }    fSource.Write(tempbuffer,30);
                ZeroMemory(tempbuffer,30);//将test2.exe的长度转换成字符串,如果长度不够30就添加空格至30,再添加到文件尾部
        itoa(len,tempbuffer,10);
        
        while (strlen(tempbuffer) < 30)
        {
            strcat(tempbuffer," ");
        }
        
        fSource.Write(tempbuffer,30);    fSource.Close();    ::MessageBox(NULL,"捆绑完成","提示",MB_ICONINFORMATION);OK,这样我们就生成了一个新文件target.exe,这个target.exe的结构上面已经说了。执行target.exe后,aaa.exe首先得到执行,然后test1.exe和test2.exe都会执行。为了增强隐蔽性,我们在aaa.exe的OnInitDialog()函数里写下如下代码:
        ModifyStyleEx(WS_EX_APPWINDOW, WS_EX_TOOLWINDOW);
        ::MoveWindow(m_hWnd,0,0,0,0,TRUE);
    这样aaa.exe执行的时候没窗口,也不会在任务栏上显示任务条。是转贴
      

  6.   

    非常感谢大家的回帖和支持................~~
    我要申明下,我的主体意思是什么,好象大家都误会了~~`
    第一,已经有一个exe文件,并且他是全屏显示的
    第二,我要写一个exe文件来控制他启动。(启动已经能做到了)
    第三,我写的exe要能将已有的exe窗口化(关键是还不能把他窗口化)
      

  7.   

    我还有个想法,不知道可行否,且我没试过。exe1,和exe2,exe1启动exe2,exe2嵌入到exe1是这样吧?不知道你知不知道屏保程序的运行原理:dll嵌入exe . 这种情况是在屏保设置的那个预览小窗口。你在选择屏保程序时, 会在那个小窗口看到预览。它们是两个程序,和你的一致。
    实现无非就这么一条:主窗口启动一个程序时,把自己的窗口句柄做为参数传入另一个程序,另一个程序在启动是会检查是否有程序参数,如果有将这个参数转换成窗口句柄,并做为本程序主窗口的父窗口,从而实现exe的嵌入。因为它符合windows的机制。