Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/18: Рейтинг темы: голосов - 18, средняя оценка - 4.89
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
.NET 4.x

[StructLayout(LayoutKind.Explicit)] и массивы

18.12.2015, 14:20. Показов 3480. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго времени суток, помогите разобраться с некоторыми нюансами, есть такая вот структура:
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
 [StructLayout(LayoutKind.Explicit, Size = 9320)]
    public class testss
    {
        [FieldOffset(0)]private double dt;
        public double Dt { get { return dt; } set { dt = value; } }
 
        [FieldOffset(8)]private short nbr;
        public short Nbr { get { return nbr; } set { nbr = value; } }
 
        [FieldOffset(10)]private short nsm;
        public short Nsm { get { return nsm; } set { nsm = value; } }
 
        [FieldOffset(12)]private short nr;
        public short Nr { get { return nr; } set { nr = value; } }
 
        [FieldOffset(16)]private float pt;
        public float Pt { get { return pt; } set { pt = value; } }
 
        [FieldOffset(20)]private float pf;
        public float Pf { get { return pf; } set { pf = value; } }
        
        [FieldOffset(24)]private float pdm;
        public float Pdm { get { return pdm; } set { pdm = value; } }
 
        [FieldOffset (28)]private float pdp;
        public float Pdp { get { return pdp; } set { pdp = value; } }
        
        [FieldOffset(32)]private float pbm;
        public float Pbm { get { return pbm; } set { pbm = value; } }
 
        [FieldOffset(36)]private float pbp;
        public float Pbp { get { return pbp; } set { pbp = value; } }
 
        [FieldOffset(40)]private float pu;
        public float Pu { get { return pu; } set { pu = value; } }
 
        [FieldOffset(44)]private float pe;
        public float Pe { get { return pe; } set { pe = value; } }
 
         [FieldOffset(48)]
        private float[] Ps;
        public float[] ps { get { return Ps; } set { Ps = value; } }
 
        [FieldOffset (96)]private float[] ph ;
        public float[] Ph { get { return ph; } }
 
/*[MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
private float[] phu;
public float[] Phu { get { return phu; } }
public int prs { get; set; }
 
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
private short[] pr;
public short [] Pr {get {return pr;}}
 
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
private short[] kr;
public short[] Kr { get { return kr; } }
 
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 16)]
private uint[] m;
public uint[] M { get { return m; } }
 
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 16)]
private uint[] s;
public uint[] S { get { return s; } }
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 4)]
private float[] frez;
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 4)]
private int[] irez;
 
public float[] Frez { get { return frez; } }
public int[] Irez { get { return irez; } }*/
    };
Все что закомментировано в стадии разработки. Когда я использовал автоматическое выделение памяти [StructLayout(LayoutKind.Sequential)] проблем с массивом не было, это и понятно что такое представление
[MarshalAs(UnmanagedType.ByValArray, SizeConst=12)]
передает ссылку на типизированный массив, мы можем передать его по значению, и система сконвертирует его в массив фиксированной длины и обратно в управляемый массив без дополнительных действий с нашей стороны. Но теперь мне понадобилось фиксировать память структуры, все бы нечего но проблема с массивами.

повторюсь объявляю и выделяю память так
C#
1
2
3
4
5
6
[FieldOffset(48)]
        private float[] Ps;
        public float[] ps { get { return Ps; } set { Ps = value; } }
 
        [FieldOffset (96)]private float[] ph ;
        public float[] Ph { get { return ph; } }
но получаю ошибку "Попытка чтения или записи в защищенную память. Это часто свидетельствует о том, что другая память повреждена."

Хотя если убрать массив и просто объявить переменную, то по данному адресу памяти я получаю то число прочитанное с бинарного файла которое мне нужно.

Прочитал что можно объявлять без массива выделяя просто память. Тогда как обращаться к остальным данным массива ? помогите пожалуйста разобраться.

Далее приведу код чтения может там таится ошибка :
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
using (var readeri = new BinaryReader(File.OpenRead(S)))      { 
  var obj = ReadStructs<testss>(readeri);            
}
 
 
T ReadStructs<T>(BinaryReader readeri) where T : class, new()
{
byte[] rawDataa =readeri.ReadBytes(Marshal.SizeOf(typeof(T)));
GCHandle handlee = GCHandle.Alloc(rawDataa,GCHandleType.Pinned);
var returnObjectt = (T)Marshal.PtrToStructure(handlee.AddrOfPinnedObject(), typeof(T));
handlee.Free();
return returnObjectt;
}
Всем спасибо.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.12.2015, 14:20
Ответы с готовыми решениями:

Cкорость работы при использовании LayoutKind.Auto и LayoutKind.Explicit
И снова вопрос по Джефри Рихтеру (стр. 155), нет полной ясности для этих двух атрибутов Ранее никогда не пользовался ни одним из них,...

StructLayout и размер структуры
Доброго времени суток. Подскажите, почему экземпляр структуры MyStruct занимает 4 байта, а экземпляр структуры MyStruct2 занимает 3...

Изменение размера структуры (StructLayout)
Помогите изменить размер структуры! Надо, чтобы размер был 28 байт, а он 32! private struct ROUTE_CREATE ...

14
 Аватар для Konctantin
970 / 773 / 171
Регистрация: 12.04.2009
Сообщений: 1,700
18.12.2015, 15:35
Столько заморочки вы сделали со всем этим делом, проще просто прочитать с помощью BinaryReader.
Записать / прочитать по отдельности каждое поле.
1
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
18.12.2015, 18:07  [ТС]
Konctantin, Все началось с того что на работе пришлось уйти от 15 студии, а 12-13я стали вылетать с исключением ссылаясь на дату\время, вот тогда мне посоветовали тип DataTime заменить на bool и после перевести в дату время, так же на не управляемой структуре выделить столько памяти сколько нужно, уйти от автоматических свойств, используя поля и свойства (что оказалось эффективным, например не нужно делать каких-то округлений в конвертере а можно сделать это в свойстве, удобно даже). Почитав документацию я приступил к практике, и получилось, мой проект стал работать на любой версии студии, хорошо подумал я и решил изменить данные и получил другое исключение, поэтому хочу разобраться, можно ли используя [StructLayout(LayoutKind.Explicit)] читать массивы и т.д. Спасибо большое за ваши ответы.
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18294 / 14218 / 5368
Регистрация: 17.03.2014
Сообщений: 28,896
Записей в блоге: 1
18.12.2015, 22:37
Dostik, массив это ссылочный тип и хранится отдельно. Поэтому указанные смещения и размеры не оказывают нужного эффекта. Задачу можно решить используя fixed массивы (требуется unsafe контекст).
1
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
21.12.2015, 19:10  [ТС]
Всем доброго времени суток, сделал все по совету OwenGlendower, структура теперь имеет следующий вид:
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
 [StructLayout(LayoutKind.Explicit, Size = 9320)]
   unsafe public struct testss
    {
        [FieldOffset(0)]private double dt;
        public double Dt { get { return dt; } set { dt = value; } }
 
        [FieldOffset(8)]private short nbr;
        public short Nbr { get { return nbr; } set { nbr = value; } }
 
        [FieldOffset(10)]private short nsm;
        public short Nsm { get { return nsm; } set { nsm = value; } }
 
        [FieldOffset(12)]private short nr;
        public short Nr { get { return nr; } set { nr = value; } }
 
        [FieldOffset(16)]private float pt;
        public float Pt { get { return pt; } set { pt = value; } }
 
        [FieldOffset(20)]private float pf;
        public float Pf { get { return pf; } set { pf = value; } }
        
        [FieldOffset(24)]private float pdm;
        public float Pdm { get { return pdm; } set { pdm = value; } }
 
        [FieldOffset (28)]private float pdp;
        public float Pdp { get { return pdp; } set { pdp = value; } }
        
        [FieldOffset(32)]private float pbm;
        public float Pbm { get { return pbm; } set { pbm = value; } }
 
        [FieldOffset(36)]private float pbp;
        public float Pbp { get { return pbp; } set { pbp = value; } }
 
        [FieldOffset(40)]private float pu;
        public float Pu { get { return pu; } set { pu = value; } }
 
        [FieldOffset(44)]private float pe;
        public float Pe { get { return pe; } set { pe = value; } }
 
       
         [FieldOffset(48)]
        public fixed float ps[12];
};
и чтение работает вроде как хорошо. Вопрос возник в следующем:
- Использовать теперь поле, свойство не получиться ? ну тоесть как было раньше:
C#
1
2
3
4
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 4)]
private float[] irez;
 
public float[] Irez { get { return irez; } }
- Как теперь обращаться к элементам массива ? пока обращаюсь следующим образом - так как структура у меня заполняется из бинарного файл? то я просто вытягиваю данные из oob var oob = ReadStructs<testss>(readeri); а не из структуры :
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
  public partial class MainWindow : Window
    {public ObservableCollection<testss> List { get; private set; }
public MainWindow()
        {
        List  = new ObservableCollection<testss>();
        InitializeComponent();
        DataContext = List;   
}
private void CommandBinding_Open_Executed(object sender, ExecutedRoutedEventArgs e)
        {
 
            List.Clear();
 using  (var readeri = new BinaryReader(File.OpenRead(S)))
                        {
 
                            testss jj = new testss();
                            var oob = ReadStructs<testss>(readeri);
                             
                           unsafe {
                            label.Content = (oob.ps[11]); // Так получаю нужные значения, правильно так обращаться ?
                           // label.Content = (jj.ps[11]);  // Весь массив равен 0
                           }
                  
                        }
                    }
И еще что хотел спросить так это про этот участок
C#
1
2
3
 unsafe {
                            label.Content = (oob.ps[11]); // Так получаю нужные значения, правильно так обращаться ?
                           }
а именно что бы обращаться к неуправляемому коду, нужно постоянно объявлять unsafe ?
Всем большое спасибо.

Добавлено через 1 минуту
А и в дополнение забыл спросить, как теперь с такой структурой будет работать запись в файл ? Есть похожие примеры ?

Добавлено через 1 час 35 минут
и еще вопрос как выводить эти данные в таблицу делал след. образом :
XML
1
 <DataGridTextColumn Header="ps" Binding="{Binding ps}" />
Ничего не вышло
и так тоже пробовал:
XML
1
<DataGridTextColumn Header="ps" Binding="{Binding ps[1]}" />
тоже ничего не вышло, так как тогда выводить данные в datagrid ?

Добавлено через 4 часа 20 минут
Один ответ на свой вопрос я нашел :
Вопрос возник в следующем:
- Использовать теперь поле, свойство не получиться ? ну тоесть как было раньше:
C#
1
2
3
4
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 4)]
private float[] irez;
 
public float[] Irez { get { return irez; } }
Небезопасные буферы могут быть только полями экземпляра структур в небезопасном контексте.
Следующие вопросы пока в силе, спасибо.
0
Эксперт .NET
6691 / 4102 / 1607
Регистрация: 09.05.2015
Сообщений: 9,574
21.12.2015, 19:36
Лучший ответ Сообщение было отмечено Dostik как решение

Решение

Незнаю зачем тут unsafe и fixed и чем вас не устроил
C#
1
[MarshalAs(UnmanagedType.ByValArray, SizeConst=12)]
К тому же, разницы между [StructLayout(LayoutKind.Sequential)] и [StructLayout(LayoutKind.Explicit)] в вашем случае нет.
Миниатюры
[StructLayout(LayoutKind.Explicit)] и массивы  
1
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
21.12.2015, 19:43  [ТС]
Someone007, Не знал что так можно, большое спасибо. Так-то меня [MarshalAs(UnmanagedType.ByValArray, SizeConst=12)]
вполне устраивал. Просто [StructLayout(LayoutKind.Explicit, Size = 9320)] требует объявления [FieldOffset(0)] но никто не сказал что можно делать тоже самое используя сначала [FieldOffset(0)] а затем [MarshalAs(UnmanagedType.ByValArray, SizeConst=12)]
Еще раз спасибо.
0
Эксперт .NET
6691 / 4102 / 1607
Регистрация: 09.05.2015
Сообщений: 9,574
21.12.2015, 20:00
А еще можно в одну строку атрибуты записать
C#
1
2
[FieldOffset(16), MarshalAs(UnmanagedType.ByValArray, SizeConst = 2)]
public float[] fa;
1
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
22.12.2015, 09:06  [ТС]
Всем доброго времени суток, столкнулся с непонятной проблемой
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
  [FieldOffset(48)]
        [MarshalAs(UnmanagedType.ByValArray, SizeConst = 12)]
        private float[] Ps;
        public  float[] ps { get { return Ps; } set { Ps = value; } }
      //  public fixed float ps[12] { get { return Ps[12] ; } set { Ps = value; } }
 
        [FieldOffset (96)]
        [MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
        private float[] Ph ;
        public  float[] ph { get { return Ph; } set { Ph = value; } }
        //public float Ph { get { return ph; } }
 
        [FieldOffset(128)]
        [MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
        private  float[] Phu ;
        public   float[] phu { get { return Phu; } set { Phu = value; } }
//public float[] Phu { get { return phu; } }
        [FieldOffset(160)]private int Prs; // { get; set; }
        public int prs { get { return Prs; } set { Prs = value; } }
 
        [FieldOffset (164)]
        [ MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
       private  short[] Pr ;
       public   short[] pr { get { return Pr; } set { Pr = value; } }
три первых массива отображаются как надо, четвертый массив вылетает с исключением :
Additional information: "Вызов конструктора для типа "WpfApplication1.MainWindow", удовлетворяющего указанным ограничениям привязки, привел к выдаче исключения.": номер строки "7" и позиция в строке "64".
С чем может быть связанна данная проблема ?
И еще если я сделаю смещение на 4 байта тогда исключения нет, но и данный смещаются, и первых 4-х байт я не получаю. Помогите разобраться всем спасибо
0
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
22.12.2015, 11:54  [ТС]
Приложу лучше проект, так будет понятнее, чем угадывать ... testn.rar.

Не по теме:

У кого будет возможность и желание, посмотрите что не так с сохранением данных в файл. Спасибо

0
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
25.12.2015, 08:21  [ТС]
Все еще актуально ...
0
Почетный модератор
Эксперт .NET
 Аватар для NickoTin
8728 / 3680 / 404
Регистрация: 14.06.2010
Сообщений: 4,513
Записей в блоге: 9
26.12.2015, 16:35
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
    [StructLayout(LayoutKind.Sequential)]
    public struct otto
    {
        //[FieldOffset(0)]
        private double dt;
        public DateTime Dt { get { return DateTime.FromOADate(dt); } } 
 
        //[FieldOffset(8)]
        private short nbr;
        public short Nbr { get { return nbr; } set { nbr = value; } }
 
        //[FieldOffset(10)]
        private short nsm;
        public short Nsm { get { return nsm; } set { nsm = value; } }
 
        //[FieldOffset(12)]
        private short nr;
        public short Nr { get { return nr; } set { nr = value; } }
 
        private short Reserved0;
 
        //[FieldOffset(16)]
        private float pt;
        public float Pt { get { return pt; } set { pt = value; } }
 
        //[FieldOffset(20)]
        private float pf;
        public float Pf { get { return pf; } set { pf = value; } }
 
        //[FieldOffset(24)]
        private float pdm;
        public float Pdm { get { return pdm; } set { pdm = value; } }
 
        //[FieldOffset(28)]
        private float pdp;
        public float Pdp { get { return pdp; } set { pdp = value; } }
 
        //[FieldOffset(32)]
        private float pbm;
        public float Pbm { get { return pbm; } set { pbm = value; } }
 
        //[FieldOffset(36)]
        private float pbp;
        public float Pbp { get { return pbp; } set { pbp = value; } }
 
        //[FieldOffset(40)]
        private float pu;
        public float Pu { get { return pu; } set { pu = value; } }
 
        //[FieldOffset(44)]
        private float pe;
        public float Pe { get { return pe; } set { pe = value; } }
 
 
        //[FieldOffset(48)]
        [MarshalAs(UnmanagedType.ByValArray, SizeConst = 12)]
        private float[] Ps;
        public float[] ps { get { return Ps; } set { Ps = value; } }
 
        //[FieldOffset(96)]
        [MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
        private float[] Ph;
        public float[] ph { get { return Ph; } set { Ph = value; } }
 
        //[FieldOffset(128)]
        [MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
        private float[] Phu;
        public float[] phu { get { return Phu; } set { Phu = value; } }
 
        //[FieldOffset(160)]
        private int Prs; 
        public int prs { get { return Prs; } set { Prs = value; } }
         
       //[FieldOffset(164)]                                       // получаемые данные [0] = 904;                                                                                    
       [MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]     //[1]=3404; [2]=2576; [3]=1631; [4]=3601; [5]=834; [6]=0; [7]=2578;
       private short[] Pr;                                      // а если сместить на 4 байта тогда нормально компил. 
       public short[] pr { get { return Pr; } set { Pr = value; } } //и дальше все переменные вылетают с тем же исключением.
 
        //[FieldOffset(180)]
      //  [MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
     //   private short[] kr;
     //   public short[] Kr { get { return kr; } }
 
        //[FieldOffset (196)]
        //[MarshalAs(UnmanagedType.ByValArray, SizeConst = 16)]
        //     private  uint[] m ;
        //     public uint[] M { get { return m; } }
 
        //[FieldOffset (260)]public fixed uint s[16];
        //public uint[] S { get { return s; } }
        //[FieldOffset (380)]public fixed float frez[16];
        /*[MarshalAs(UnmanagedType.ByValArray, SizeConst = 4)]
        private int[] irez;
 
        public float[] Frez { get { return frez; } }
        public int[] Irez { get { return irez; } }*/
    }
Совет: прочитайте про MVVM и как он используется в WPF; биндить структуры - плохое решение, сделайте какой-нибудь класс-враппер; структуры должны быть максимально простыми, не нужно на каждое поле по "авто"-свойству наматывать.
2
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
28.12.2015, 08:40  [ТС]
Всем доброго времени суток, извиняюсь что долго не отвечал, и так возникли некоторые вопросы по ответу NickoTin, вы уходите от заданного объема памяти, переводя его в автоматический, для чего ? так вам удобнее ? или какие-то есть особенные критерии. Почему такой вопрос, ну потому как я выкладывал свой проект на форуме msdn с другим вопросом, и там мне посоветовали уйти от автоматического выделения памяти. Да и Konctantin, делал подобное решение только с другой структурой. Пожалуйста объясните подробнее данное решение, и чем оно лучше ?
Второй вопрос почему же плохо биндить структуры ? тогда что нужно биндить, не совсем понял про класс-враппер ? но если у меня чтение структуры из бинарного файла, причем запись некоторых данных производиться ежесекундно, и более по интервалу времени, какое тогда должно быть решение ?
0
 Аватар для Konctantin
970 / 773 / 171
Регистрация: 12.04.2009
Сообщений: 1,700
28.12.2015, 10:59
Лучший ответ Сообщение было отмечено Dostik как решение

Решение

Это лишнее. указывать смещения полей если они и так выравнены.
указывать структуру необязательно, можно использовать класс (вся разница в том, что компилятор в классе может поля расположить в каком угодно порядке, но аттрибут [StructLayout(LayoutKind.Sequential)] запретит ему это делать, и вести себя класс при маршалинге будет так же как и со структурой).

ЗЫ. Я вам скоро покажу пример того что у меня получилось, просто нету времени никак закончить (предновогоднее бешенство на работе )
1
 Аватар для Dostik
38 / 38 / 4
Регистрация: 31.05.2011
Сообщений: 580
28.12.2015, 11:06  [ТС]
Konctantin, Большое спасибо за объяснение, переделал все классы (структуры) чтение нормально, проблемы с записью. Но это уже в другой теме. Всем спасибо

ЗЫ. Большое спасибо, не торопитесь, как будет время и возможность тогда и доделаете.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.12.2015, 11:06
Помогаю со студенческими работами здесь

Как использовать StructLayout Pack?
я знал, да что то позабыл как использовать StructLayout Pack? он же вроде определяет выравнивание, так что логично было бы его в 0 задать...

Доступ к полю StructLayout из экземпляра класса
Есть структура с переналоженными полями: internal struct w64 { internal double d; ...

explicit и последствия.
Здравствуйте. Как я узнал, в С++ есть ключевое слово explicit, применяемое к конструкторам с одним параметром ( или, как я понял, большим...

Функция explicit
Добрый день, господа. Вопрос тот же, примеры во вложении. Заранее благодарен за проявленное внимание. Версия Маткада - 15 M040 ...

Функция explicit
В приложенной картинке выделены 2 формулы. Как сделать, чтобы во вторую формулу подставилось значение Iном.дв.=29.433, а не вся дробь?...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru