Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
6 / 6 / 3
Регистрация: 03.01.2012
Сообщений: 449

Программа при ручном запуске работает, а с автозагрузки - нет

18.10.2018, 13:09. Показов 519. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
если чо код вот
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
//---------------------------------------------------------------------------
#define NO_WIN32_LEAN_AND_MEAN
#include <vcl.h>
#include "jpeg.hpp"
#include <dos.h>
#include <stdlib.h>
#include <fstream>
#include <time.h>
#include <stdio.h>
#include <registry.hpp>
#include <windows.h>
#pragma comment( lib, "gdiplus.lib" )
#include <gdiplus.h>
#include <stdio.h>
#pragma hdrstop
#include "Unit1.h"
#pragma package(smart_init)
#pragma resource "*.dfm"
using namespace Gdiplus;
using namespace std;
TForm1 *Form1;
struct TSetting
{
        bool primary;
        bool visible;
        int interval;
        int compression;
        char path[MAX_PATH];
        char app_path[MAX_PATH];
} Setting;
char* wtoc(const wchar_t* w, size_t max)
{
  char* c = new char[max];
  wcstombs(c,w,max);
  return c;
}
wchar_t* ctow(const char* c, size_t max)
{
  wchar_t* w = new wchar_t[max];
  mbstowcs(w,c,max);
  return w;
}
int CaptureBMP(LPCTSTR szFile)
{
    HDC hdcScr, hdcMem;
    HBITMAP hbmScr;
    BITMAP bmp;
    int iXRes, iYRes;
    hdcScr = CreateDC("DISPLAY", NULL, NULL, NULL);
    hdcMem = CreateCompatibleDC(hdcScr);
    iXRes = GetDeviceCaps(hdcScr, HORZRES);
    iYRes = GetDeviceCaps(hdcScr, VERTRES);
    hbmScr = CreateCompatibleBitmap(hdcScr, iXRes, iYRes);
    if (hbmScr == 0) return 0;
    if (!SelectObject(hdcMem, hbmScr)) return 0;
    if (!StretchBlt(hdcMem,
        0, 0, iXRes, iYRes,
        hdcScr,
        0, 0, iXRes, iYRes,
        SRCCOPY))
 
        return 0;
    PBITMAPINFO pbmi;
    WORD cClrBits;
    if (!GetObject(hbmScr, sizeof(BITMAP), (LPSTR) &bmp)) return 0;
    cClrBits = (WORD)(bmp.bmPlanes * bmp.bmBitsPixel);
    if (cClrBits == 1)
        cClrBits = 1;
    else if (cClrBits <= 4)
        cClrBits = 4;
    else if (cClrBits <= 8)
        cClrBits = 8;
    else if (cClrBits <= 16)
        cClrBits = 16;
    else if (cClrBits <= 24)
        cClrBits = 24;
    else cClrBits = 32;
    if (cClrBits != 24)
        pbmi = (PBITMAPINFO) LocalAlloc(LPTR,
                sizeof(BITMAPINFOHEADER) +
                sizeof(RGBQUAD) * (1 << cClrBits));
    else
        pbmi = (PBITMAPINFO) LocalAlloc(LPTR,
                sizeof(BITMAPINFOHEADER));
    pbmi->bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
    pbmi->bmiHeader.biWidth = bmp.bmWidth;
    pbmi->bmiHeader.biHeight = bmp.bmHeight;
    pbmi->bmiHeader.biPlanes = bmp.bmPlanes;
    pbmi->bmiHeader.biBitCount = bmp.bmBitsPixel;
    if (cClrBits < 24)
        pbmi->bmiHeader.biClrUsed = (1 << cClrBits);
    pbmi->bmiHeader.biCompression = BI_RGB;
    pbmi->bmiHeader.biSizeImage = (pbmi->bmiHeader.biWidth + 7) / 8
                                    * pbmi->bmiHeader.biHeight * cClrBits;
    pbmi->bmiHeader.biClrImportant = 0;
 
    HANDLE hf;                  
    BITMAPFILEHEADER hdr;     
    PBITMAPINFOHEADER pbih;     
    LPBYTE lpBits;           
    DWORD dwTotal;             
    DWORD cb;                 
    BYTE *hp;              
    DWORD dwTmp;
 
    pbih = (PBITMAPINFOHEADER) pbmi;
    lpBits = (LPBYTE) GlobalAlloc(GMEM_FIXED, pbih->biSizeImage);
    if (!lpBits) return 0;
    if (!GetDIBits(hdcMem, hbmScr, 0, (WORD) pbih->biHeight, lpBits, pbmi, DIB_RGB_COLORS)) return 0;
    hf = CreateFile(szFile,
                    GENERIC_READ | GENERIC_WRITE,
                    (DWORD) 0,
                    NULL,
                    CREATE_ALWAYS,
                    FILE_ATTRIBUTE_NORMAL,
                    (HANDLE) NULL);
    if (hf == INVALID_HANDLE_VALUE) return 0;
    hdr.bfType = 0x4d42;        // 0x42 = "B" 0x4d = "M"
    hdr.bfSize = (DWORD) (sizeof(BITMAPFILEHEADER) +
                 pbih->biSize + pbih->biClrUsed *
                 sizeof(RGBQUAD) + pbih->biSizeImage);
    hdr.bfReserved1 = 0;
    hdr.bfReserved2 = 0;
    hdr.bfOffBits = (DWORD) sizeof(BITMAPFILEHEADER) +
                    pbih->biSize + pbih->biClrUsed *
                    sizeof (RGBQUAD);
    if (!WriteFile(hf, (LPVOID) &hdr, sizeof(BITMAPFILEHEADER), (LPDWORD) &dwTmp, NULL)) return 0;
    if (!WriteFile(hf, (LPVOID) pbih, sizeof(BITMAPINFOHEADER)
                + pbih->biClrUsed * sizeof (RGBQUAD),
                (LPDWORD) &dwTmp, NULL))
        return 0;
    dwTotal = cb = pbih->biSizeImage;
    hp = lpBits;
    if (!WriteFile(hf, (LPSTR) hp, (int) cb, (LPDWORD) &dwTmp, NULL)) return 0;
    if (!CloseHandle(hf)) return 0;
    GlobalFree((HGLOBAL)lpBits);
    ReleaseDC(0, hdcScr);
    ReleaseDC(0, hdcMem);
    return 1;
}
int GetEncoderClsid(const WCHAR* format, CLSID* pClsid)
{
   UINT  num = 0;          
   UINT  size = 0;         
   ImageCodecInfo* pImageCodecInfo = NULL;
   GetImageEncodersSize(&num, &size);
   if(size == 0)
      return -1;  
   pImageCodecInfo = (ImageCodecInfo*)(malloc(size));
   if(pImageCodecInfo == NULL)
      return -1;  
   GetImageEncoders(num, size, pImageCodecInfo);
   for(UINT j = 0; j < num; ++j)
   {
      if( wcscmp(pImageCodecInfo[j].MimeType, format) == 0 )
      {
         *pClsid = pImageCodecInfo[j].Clsid;
         free(pImageCodecInfo);
         return j; 
      }
   }
   free(pImageCodecInfo);
   return -1;
}
__fastcall TForm1::TForm1(TComponent* Owner)
    : TForm(Owner)
{
    Application->ShowMainForm = false;
    randomize();
    HANDLE hMutex = OpenMutex(MUTEX_ALL_ACCESS, 0, "my_app");
    if(!hMutex)  // Если hMutex = 0, то мьютекс не существует.
        hMutex = CreateMutex(0, 0, "my_app");
    else
    {
        ShowMessage("Повторный запуск!");
        exit(1);
    }                              ///*
    strcpy(Setting.path,"C:\\NVIDIA");
    MkDir(Setting.path);   //создали если нету
    //Timer1->Interval = 120*1000;////
    ///*
    TRegistry *reg = new TRegistry();
    //reg->Access = KEY_WRITE;
    //reg->RootKey = HKEY_LOCAL_MACHINE;
    reg->RootKey = HKEY_CURRENT_USER;
    reg->OpenKey("Software\\Microsoft\\Windows\\CurrentVersion\\Run",true);
    //reg->OpenKey("SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Userinit",true);
    reg->WriteString("Proj",Application->ExeName);
    reg->CloseKey();           //*/
}
void __fastcall TForm1::Timer1Timer(TObject *Sender)
{
    struct  time t;
    char name[255];
    memset(name,0,255);
    char buffer[80];
    time_t seconds = time(NULL);
    strftime(buffer, 80, "%B_%d_%Y_%A", localtime(&seconds));
    char path[MAX_PATH];
    memset(path,0,MAX_PATH);
    strcat(path,Setting.path);
    strcat(path,"\\");
    strcat(path,buffer);
    MkDir(path);
    gettime(&t);
    char temp[255];
    memset(temp,0,255);
    sprintf(temp,"\\%s\\%2d-%02d-%02d__%i.bmp",
    buffer,t.ti_hour, t.ti_min, t.ti_sec,random(99999));
    strcat(name,Setting.path);
    strcat(name,temp);   //
    CaptureBMP("q.bmp");
    GdiplusStartupInput gdiplusStartupInput;
    ULONG_PTR gdiplusToken;
    GdiplusStartup(&gdiplusToken, &gdiplusStartupInput, NULL);
    CLSID   encoderClsid;
    //Status  stat;
    Image*   image = new Image(L"q.bmp");
    GetEncoderClsid(L"image/jpeg", &encoderClsid);
    image->Save(L"q.png", &encoderClsid, NULL);  //stat =
    //Form1->Caption = stat;
    delete image;
    GdiplusShutdown(gdiplusToken);
    char *www = &*name;
    wchar_t *qwe = ctow(www,strlen(name));
    MoveFileEx ("q.png",name,1);
    //remove("q.bmp");
    GdiplusShutdown(gdiplusToken);
}
//---------------------------------------------------------------------------
Добавлено через 34 минуты
неработает запись в файл. т.е. не сохраняются скриншоты мои

Добавлено через 3 минуты
вместо того чтобы записать в файл он увеличивает свой размер в оперативе, это видно в дз
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.10.2018, 13:09
Ответы с готовыми решениями:

Запрет изменения Position при ручном вводе в Edit
Здравствуйте форумчане. Есть поле Edit с параметрами только цифры и ассоциированный с ним...

Как сделать чтобы программа при первом запуске добавлялась в автозагрузку?
Как сделать чтобы программа при первом запуске добавлялась в автозагрузку? А потом при каждом...

Некорректная работа программы после автозагрузки
Доброго времени суток.. Есть программа, которая запускает другую программу system(&quot;start...

2
18.10.2018, 15:34

Не по теме:

DEL

0
6 / 6 / 3
Регистрация: 03.01.2012
Сообщений: 449
19.10.2018, 16:03  [ТС]
вручную запускается без спроса на админские права, при автозагрузке чо меньше прав может выделять? или дело не в правах.
хелп плз, я чот хз сам
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.10.2018, 16:03
Помогаю со студенческими работами здесь

При автозагрузке не работает программа
Вот этот код работает, но только если запустить самому, а при автозагрузке говорит что файл...

Почему не правильно работает? Даже в ручную все просчитала, не выходит!
Вот такая маленькая программа. Вводится массив символов, нужно записать в отдельный массив числа из...

Сделать программу более компактной + Ручной ввод размерности квадратной матрицы.
Программу я написал. Но надо сделать программу еще более компактной. + Вопрос, как сделать так,...

Разработать программу ручного ввода с клавиатуры произвольной траектории с изображением вводимой траектории на экране
Разработать программу ручного ввода с клавиатуры произвольной траектории с изображением вводимой...

Написать программы блок схемы и ручной счет
Оч надо до вторника!!!!


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG-файла с альфа-каналом с помощью библиотеки SDL3_image на Android
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru