Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 11.01.2020
Сообщений: 6

Winapi ошибка "недопустимый параметр был передан функции"

16.05.2020, 12:40. Показов 1016. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Пишу программу в WinApi, которая анализирует и предоставляет данные сенсора в окошке (в данном случае это обороты элемента).
Сначала пишу часть кода в с++ и лишь когда он работает, переношу его на код в VisualStudio winapi. Иногда требуются небольшие корректировки, но это мелочь.

Код считает обороты правосторонние и левосторонние (угол оборота (-180;0]u[0;180).
Считая правосторонние обороты, все в проходит хорошо, но при счете левосторонних (отрицательных) в функции licz_obroty выдает ошибку
"An invalid parameter was passed to a function that considers invalid parameters fatal".
В этом случае я понятия не имею, как ее ликвидировать, хотя раньше удавалось.

Самое интересное то, что если не вызывать эту функцию, а заняться функцией przesun_kat_dla_grafu, то при аналогичных обстоятельствах выдает аналогичную ошибку. Выходит, проблема заключается в векторе? Но значения допустимы...

Искренне надеюсь на Вашу помощь.

Фрагмент кода программы:

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
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
#include "stdafx.h"
#include "draw2.h"
#include <vector>
#include <cstdio>
#include <fstream>
#include <iostream>
#include <cstring>
#include <sstream>
#include <string>
#include <iomanip>
 
 
#define MAX_LOADSTRING 100
#define TMR_1 1
 
// Global Variables:
HINSTANCE hInst;                                // current instance
TCHAR szTitle[MAX_LOADSTRING];                  // The title bar text
TCHAR szWindowClass[MAX_LOADSTRING];            // the main window class name
 
INT value;
 
//********** - mozna zmieniac, podstawiac inna wartosc, jesli rozpatrywac inny przypadek
 
// DEKLAROWANE DANE
struct przesun {
    int poziomo;
    int pionowo;
};
 
std::vector <double> roll; 
std::vector <double> pitch;
std::vector <double> yaw;
std::vector<double> vec; // vec - ten wektor ktory bedziemy obserwowac, tylko zakres katowy zmienia sie z [-180;180] na [0;360]
std::vector <double> wybr; // ten sam wybrany wektor s zakresem katowym [-180;180]
std::vector<przesun> kat; // kat - wektor struktur, pokazujacy, o ile pikseli trzeba przesunac kat obrotu; do rysowania katu 
 
int j = 0; // dlugosc powyzszyvh wektorow - 1
int i = 0; // dla rysowania katu
 
// FUNKCJE
int Wczytaj_roll_pitch_yaw(); // f-cja wczytuje dane katowe z pliku
void licz_obroty(int j); // f-cja liczy obroty prawostronne i lewostronne 
void przetworz_wektor_na_wygodny(int j, std::vector <double> &vec); // funkcja zmienia zakres kata, ktory obserwujemy z [-180;180] na [0;360]
void czy_900_stopni(double &obr_p, double &obr_l, int y, double &dsp, double &dsl, std::vector <double> vec); //f-cja sprawdza, czy cialo sie obrocilo o 900 stopni  (2.5 obrotu)
void przesun_kat_dla_grafu(int j, std::vector <double> vec); // f-cja tworzaca wektor struktur kat, ktory zawiera dane, o ile pikseli trzeba przesunac kat
 
 
// buttons
HWND hwndButton;
 
// sent data
int col = 0;
std::vector<Point> data;
RECT drawArea1 = { 0, 0, 550, 400 }; // obszar, gdzie robimy repaint
RECT drawArea2 = { 50, 400, 650, 422};
 
// Forward declarations of functions included in this code module:
ATOM                MyRegisterClass(HINSTANCE hInstance);
BOOL                InitInstance(HINSTANCE, int);
LRESULT CALLBACK    WndProc(HWND, UINT, WPARAM, LPARAM);
INT_PTR CALLBACK    About(HWND, UINT, WPARAM, LPARAM);
INT_PTR CALLBACK    Buttons(HWND, UINT, WPARAM, LPARAM);
 
 
int Wczytaj_roll_pitch_yaw()
{
    std::ifstream plik;
    plik.open("hPlik.log", std::ios::binary); // mozna i nie binary
 
    if (!plik)
    {
        MessageBox(NULL, _T("Nie można otworzyć pliku."), _T("A to pech!"), MB_ICONEXCLAMATION);
        PostQuitMessage(0); // Zakończ program
    }
    int i = 0;
    std::string line;
    while (std::getline(plik, line))
    {
        if (i < 112)
        {
            std::stringstream iss(line);
            i++;
        }
        else
        {
        //  std::cout << line << std::endl;
            float x, y, z;
            std::stringstream iss(line);
 
            iss >> x >> y >> z;
 
            roll.push_back(x);
            pitch.push_back(y);
            yaw.push_back(z);
 
        //  std::cout << "\tRoll =" << std::fixed << std::setprecision(3) << roll[j] << std::endl;
        //  std::cout << "\tPitch =" << pitch[j] << std::endl;
        //  std::cout << "\tYaw =" << yaw[j] << std::endl;
            j++;
        }
    }
    j--;
    plik.close();
    return j; // f-cja zwraca dlugosc wektorow (-a) - 1 
}
 
 
void przetworz_wektor_na_wygodny (int j, std::vector <double> &vec) // funkcja zmienia zakres kata, ktory obserwujemy z [-180;180] na [0;360]
{
    vec;// vec - kopia wektora, ktory bedziemy obserwowac (tu wybralismy yaw)
    double z = vec[0]; // od tej wartosci bedziemy liczyc obroty
 
    if (vec[0] > 0) // najwygodniej liczyc obroty od 0, dlatego przesuwamy wszystkie liczby o wartosc pocz. vec[0], jest to nasz punkt poczatkowy
    {
        for (int i = 0; i < j; i++)
        {vec[i] = vec[i] - z;}
    }
 
    if (vec[0] < 0) // analogicznie jak wyzej
    {
        for (int i = 0; i < j; i++) 
        {vec[i] = vec[i] - z;}
    }
 
    for (int i = 0; i < j; i++) // ujemne wartosci liczb zamieniamy na dodatnie dodajac 360 (z tego wynika ze caly obro rowny jest 360 stopni)
    {                           // tak wygodniej liczyc obroty
        if (vec[i] < 0)
        {vec[i] = 360 + vec[i];}
    }
}
 
 
void czy_900_stopni(double &obr_p, double &obr_l, int y, double &dsp, double &dsl, std::vector <double> vec)  //f-cja sprawdza, czy cialo sie obrocilo o 900 stopni  (2.5 obrotu)
{
    if (obr_p == dsp) // jezeli jest zrobiony caly obrot (bez polowek), np. 5
    {
        std::cout << "ObrotP :" << obr_p << "; wartosc: 900 stopni" << std::endl;
        dsp = dsp + 2.5; // poszerzamy zakres obrotow (jesli jest to nadal prawostronny obrot)
    }
        
 
    if (vec[y - 1] < 180 & vec[y] >= 180) // jezeli zrobiono pol obrotu
    {
        obr_p = obr_p + 0.5;
        if (vec[y - 1] < 180 & vec[y] >= 180 & obr_p == dsp) // jezeli minelo kolejne 2.5 obrotu
        {
            std::cout << "ObrotP :" << obr_p << "; wartosc: 900 stopni" << std::endl;
            //system("pause");
            dsp = dsp + 2.5; // poszerzamy zakres obrotow (jesli jest to nadal prawostronny obrot)
        }
    }
        
    if (obr_l == dsl) // jezeli jest zrobiony caly obrot (bez polowek), np. 5
    {
        //std::cout << "ObrotL: " << obr_l << "; wartosc: 900 stopni" << std::endl;
        dsl = dsl + 2.5; // poszerzamy zakres obrotow (jesli jest to nadal lewostronny obrot)
    }
 
    if (vec[y - 1] > 180 & vec[y] <= 180) // jezeli zrobiono pol obrotu
    {
        obr_l = obr_l + 0.5;
        if (vec[y - 1] > 180 & vec[y] <= 180 & obr_l == dsl) // jezeli minelo kolejne 2.5 obrotu
        {
            std::cout << "ObrotL: " << obr_l << "; wartosc: 900 stopni" << std::endl;
            //system("pause");
            dsl = dsl + 2.5; // poszerzamy zakres obrotow (jesli jest to nadal lewostronny obrot)
        }
    }
}
 
 
void licz_obroty(int j) // f - cja liczy obroty prawostronne i lewostronne
{
    vec = yaw; //*********** vec - kopia wektora, ktory wybralismy (tu wybralismy yaw)
    vec.assign(yaw.begin(), yaw.end()); //***********
    przetworz_wektor_na_wygodny(j, vec); // przetwarzamy vec tak, zeby kat obrotu byl 360 stopni
 
    wybr = yaw; //*********** wybr - wybrany wektor, kopia wektora, ktory wybralismy (tu wybralismy yaw), ale z zakresem obrotu kata [-180;180]
    wybr.assign(yaw.begin(), yaw.end()); //***********
 
 
    double obr_p = 0; // prawostronny obrot
    double obr_l = 0; // lewostronny obrot
    int y = 0; // kiedy y == j , funkcja przestanie liczyc obroty
    int wybor = 1; // nim przelaczamy switchy
    double dsp = 2.5; // dsp - 900 stopni, obrot 2.5 dla prawostronnego obrotu
    double dsl = 2.5; // dsp - 900 stopni, obrot 2.5 dla lewostronnego obrotu
 
    while (y != j) // zakoncz petle jezeli y == j
    {
        switch (wybor)
        {
            case 1:
            {
                if (vec[y + 1] > vec[y] & (wybr[y] - wybr[0]) <= 0) // jezeli wartosci wybr[y] sa ujemne, ale wartosc sie zwieksza
                {
                    while (vec[y + 1] > vec[y] & (wybr[y] - wybr[0]) <= 0) // "wyrownuje" wartosc wybr[y] do wybr[0], zeby od tad zaczac liczyc obroty
                    {
                        y++;
                        if (y == j) // sprawdza, czy zakonczyc dzialanie petli while, to sprawdzenie jest potrzebne po kazdym y++;
                            break;
                        if (wybr[y] == wybr[y + 1]) // na wypadek, jesli z kolei beda te same wartosci kata (w outputRotateA), zeby nie bylo nieskonczonej petli
                            y++;
                    }
                    {if (y == j)
                        break; }
                    // obowiazkowe sprawdzenia
                    y++;
                    {if (y == j)
                        break;
                    if (wybr[y] == wybr[y + 1])
                        y++; } 
                    // obowiazkowe sprawdzenia
                }
 
                while (vec[y + 1] > vec[y]) // liczenie prawostronnego obrotu
                {
                    obr_l = 0; // wtedy zeruje sie ilosc lewostronnego obrotu
                    y++;
                    {if (y == j)
                        break;
                    if (wybr[y] == wybr[y + 1])
                        y++; }
                    // obowiazkowe sprawdzenia
                    czy_900_stopni(obr_p, obr_l, y, dsp, dsl, vec); // czy zrobiono 2.5 obrotu
                }
 
                if (wybr[y] < wybr[0] & wybr[y + 1] >= wybr[0]) // jezeli zrobiono caly obrot
                {
                    obr_p = obr_p + 0.5;
                    std::cout << "Obrot P: " << obr_p << std::endl;
                    czy_900_stopni(obr_p, obr_l, y, dsp, dsl, vec); 
 
                    y++;
                    {if (y == j)
                        break;
                    if (wybr[y] == wybr[y + 1])
                        y++; }
                    // obowiazkowe sprawdzenia
 
                    wybor = 1; // myslimy ze dalej bedzie prawostronny obrot
                    break;
                }
                else
                {
                    wybor = 2; // jezeli nie bedzie to prawostronny obrot, przychodzimy do liczenia lewostronnego obr.
                    break;
                }
            }
 
            case 2:
            {
                if (vec[y + 1] < vec[y] & (wybr[y] - wybr[0]) >= 0)  // jezeli wartosci wybr[y] sa dodatnie, ale wartosc maleje
                {
                    while (vec[y + 1] < vec[y] & (wybr[y] - wybr[0]) >= 0) // "wyrownuje" wartosc wybr[y] do wybr[0], zeby od tad zaczac liczyc obroty
                    {
                        y++;
                        {if (y == j)
                            break;
                        if (wybr[y] == wybr[y + 1])
                            y++; }
                        // obowiazkowe sprawdzenia
                    }
                    {if (y == j)
                        break; }
                    // obowiazkowe sprawdzenia
                    y++;
                    {if (y == j)
                        break;
                    if (wybr[y] == wybr[y + 1])
                        y++; }
                    // obowiazkowe sprawdzenia
                }
 
                while (vec[y + 1] < vec[y]) // liczenie lewostronnego obrotu
                {
                    obr_p = 0;
                    y++;
                    {if (y == j)
                        break;
                    if (wybr[y] == wybr[y + 1])
                        y++; }
                    // obowiazkowe sprawdzenia
                    czy_900_stopni(obr_p, obr_l, y, dsp, dsl, vec);
                }
 
 
                if (wybr[y] > wybr[0] & wybr[y + 1] <= wybr[0]) // jezeli zrobiono caly obrot
                {
                    obr_l = obr_l + 0.5;
                    std::cout << "Obrot L: " << obr_l << std::endl;
                    czy_900_stopni(obr_p, obr_l, y, dsp, dsl, vec);
                    
                    y++;
                    {if (y == j)
                        break;
                    if (wybr[y] == wybr[y + 1])
                        y++;}
                    // obowiazkowe sprawdzenia
 
                    wybor = 2;
                    break;
                }
                else
                {
                    wybor = 1;
                    break;
                }
            }
        }
    }
//  przesun_kat_dla_grafu(j, vec);
}
 
void przesun_kat_dla_grafu(int j, std::vector <double> vec)
{
    przesun k;
    int poz;
    int pion;
 
    for (int i = 0; i < j; i++)
    {
        kat.push_back(k);
 
        if (vec[i] > 0 & vec[i] <= 90)
        {
            if (vec[i] > 0 & vec[i - 1] < 360 & vec[i-1]>300)
            {
                poz = vec[i - 1] + vec[i];
                pion = poz;
                kat.at(i).poziomo = poz;
                kat.at(i).pionowo = pion;
            }
            else
            {
                poz = vec[i] - vec[i - 1];
                pion = poz;
                kat.at(i).poziomo = poz;
                kat.at(i).pionowo = pion;
            }
        }
 
        if (vec[i] > 90 & vec[i] <= 180)
        {
            poz = (-1)*(vec[i] - vec[i-1]);
            pion = (-1)*poz;
            kat.at(i).poziomo = poz;
            kat.at(i).pionowo = pion;
        }
 
        if (vec[i] > 180 & vec[i] <= 270)
        {
            /*if (yaw[i] > (-180) & yaw[i - 1] < 180 & yaw[i - 1]>0)
            {
                poz = (180 - yaw[i - 1]) + (180 + yaw[i]);
                if (poz > 0)
                    poz = poz * (-1);
                pion = poz;
                kat.at(i).poziomo = poz;
                kat.at(i).pionowo = pion;
            }
            else*/
            {
                poz = (yaw[i] - yaw[i-1])*(-1);
                pion = poz;
                kat.at(i).poziomo = poz;
                kat.at(i).pionowo = pion;
            }
        }
 
        if (vec[i] > 270 & yaw[i] <= 360)
        {
            poz = yaw[i] - yaw[i - 1];
            pion = (-1)*poz;
            kat.at(i).poziomo = poz;
            kat.at(i).pionowo = pion;
        }
        //system("pause");
    }
}
 
 
 
// main function (exe hInstance)
int APIENTRY _tWinMain(HINSTANCE hInstance,
    HINSTANCE hPrevInstance,
    LPTSTR    lpCmdLine,
    int       nCmdShow)
{
    UNREFERENCED_PARAMETER(hPrevInstance);
    UNREFERENCED_PARAMETER(lpCmdLine);
 
    // TODO: Place code here.
    MSG msg;
    HACCEL hAccelTable;
    value = 0;
    
    // tu powinna byc tez funkcja Wczytaj_roll_pitch_yaw(), bo bez jej zrobienia nie ruszymy dalej :(
    Wczytaj_roll_pitch_yaw();
    //przesun_kat_dla_grafu(j, vec); 
    licz_obroty(j);
 
 
    
    GdiplusStartupInput gdiplusStartupInput;
    ULONG_PTR           gdiplusToken;
    GdiplusStartup(&gdiplusToken, &gdiplusStartupInput, NULL);
 
    // Initialize global strings
    LoadString(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING);
    LoadString(hInstance, IDC_DRAW, szWindowClass, MAX_LOADSTRING);
    MyRegisterClass(hInstance);
 
 
 
    // Perform application initialization:
    if (!InitInstance(hInstance, nCmdShow))
    {
        return FALSE;
    }
 
    hAccelTable = LoadAccelerators(hInstance, MAKEINTRESOURCE(IDC_DRAW));
 
    // Main message loop:
    while (GetMessage(&msg, NULL, 0, 0))
    {
        if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg))
        {
            TranslateMessage(&msg);
            DispatchMessage(&msg);
        }
    }
 
    GdiplusShutdown(gdiplusToken);
 
    return (int)msg.wParam;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.05.2020, 12:40
Ответы с готовыми решениями:

Ошибка исполнения "недопустимый параметр был передан функции"
что за проблема недопустимый параметр был передан функции,для которой недопустимые параметры вызывают неустранимую ошибку. на фото видно...

Необработанное исключение по адресу 0x0FFCE906. Недопустимый параметр был передан функции
В Binar.cpp появляется необработанное исключение. Подскажите, как это исправить, пожалуйста. Head.cpp #include &lt;iostream&gt; ...

Недопустимый параметр был передан функции, для которой недопустимые параметры вызывают неустранимую ошибку
делаю задание с дешифрованием строки (Шфрование которой выполняется следующим образом: Шифрование выполнить следующим образом: расположить...

4
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
16.05.2020, 14:03
Отладчиком умеешь пользоваться?
0
0 / 0 / 0
Регистрация: 11.01.2020
Сообщений: 6
16.05.2020, 14:24  [ТС]
Не знаю, что это такое
0
Злостный нарушитель
 Аватар для Verevkin
10656 / 5804 / 1282
Регистрация: 12.03.2015
Сообщений: 26,798
16.05.2020, 14:56
Цитата Сообщение от Lisa_Janko Посмотреть сообщение
Не знаю, что это такое
Это такая приблуда, без которой программирование невозможно.
0
nd2
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
16.05.2020, 20:13
Цитата Сообщение от Lisa_Janko Посмотреть сообщение
Не знаю, что это такое
Как пользоваться отладчиком (в Visual Studio)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.05.2020, 20:13
Помогаю со студенческими работами здесь

Недопустимый параметр был передан функции, для которой недопустимые параметры вызывают неустранимую ошибку
Необработанное исключение по адресу 0x0F47F2F6 (ucrtbased.dll) в Dist_2.exe: Недопустимый параметр был передан функции, для которой...

Недопустимый параметр был передан функции, для которой недопустимые параметры вызывают неустранимую ошибку
Здравствуйте! Решил реализовать на с++ в visual studio 2017 обработку ввода таким образом, чтобы мы могли вводить только цифры. Взял данный...

Необработанное исключение по адресу 0x7B93F2F6 (ucrtbased.dll) в Laba_5.exe: Недопустимый параметр был передан функции,
Пишу код-вводится строка из слов, которые разделены пробелами , в слове нужно найти символ, а затем подсчитать количество слов с этим...

Недопустимый параметр был передан функции, для которой недопустимые параметры вызывают неустранимую ошбк. как исправить?
int main() { std::vector&lt;int&gt; vec{ 2,3,1,3,45,34,2,1,14,40 }; sorting&lt;int, ascending&gt; sort(vec); sort.print(); ...

Необработанное исключение по адресу 0x576CF2F6 (ucrtbased.dll) в Курсовая 4.exe: Недопустимый параметр был передан функц
Добрый день, умоляю помогите, я вообще не понимаю почему не работает. Весь код скопировал с примера и все равно. #define...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru