Google představil telefon Pixel 10a. S funkci Satelitní SOS, která vás spojí se záchrannými složkami i v místech bez signálu Wi-Fi nebo mobilní sítě. Cena telefonu je od 13 290 Kč.
Byl publikován přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Fedora 43 Asahi Remix s KDE Plasma už funguje na M3. Zatím ale bez GPU akcelerace. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.
Red Hat představil nový nástroj Digital Sovereignty Readiness Assessment (GitHub), který organizacím umožní vyhodnotit jejich aktuální schopnosti v oblasti digitální suverenity a nastavit strategii pro nezávislé a bezpečné řízení IT prostředí.
BarraCUDA je neoficiální open-source CUDA kompilátor, ale pro grafické karty AMD (CUDA je proprietární technologie společnosti NVIDIA). BarraCUDA dokáže přeložit zdrojové *.cu soubory (prakticky C/C++) přímo do strojového kódu mikroarchitektury GFX11 a vytvořit tak ELF *.hsaco binární soubory, spustitelné na grafické kartě AMD. Zdrojový kód (převážně C99) je k dispozici na GitHubu, pod licencí Apache-2.0.
Podvodné reklamy na sociálních internetových platformách, jako je Facebook, Instagram nebo X, vytvořily loni v Česku jejich provozovatelům příjmy 139 milionů eur, tedy zhruba 3,4 miliardy korun. Proti roku 2022 je to nárůst o 51 procent. Vyplývá to z analýzy Juniper Research pro společnost Revolut. Podle výzkumu je v Česku zhruba jedna ze sedmi zobrazených reklam podvodná. Je to o 14,5 procenta více, než je evropský průměr, kde je podvodná každá desátá reklama.
Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.6 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.
Czkawka a Krokiet, grafické aplikace pro hledání duplicitních a zbytečných souborů, byly vydány ve verzi 11.0. Podrobný přehled novinek v příspěvku na Medium. Od verze 7.0 je vedle frontendu Czkawka postaveného nad frameworkem GTK 4 vyvíjen nový frontend Krokiet postavený nad frameworkem Slint. Frontend Czkawka je už pouze v udržovacím módu. Novinky jsou implementovány ve frontendu Krokiet.
Jiří Eischmann na svém blogu publikoval článek Úvod do MeshCore: "Doteď mě radioamatérské vysílání úplně míjelo. Když jsem se ale dozvěděl, že existují komunity, které svépomocí budují bezdrátové sítě, které jsou nezávislé na Internetu a do značné míry taky elektrické síti a přes které můžete komunikovat s lidmi i na druhé straně republiky, zaujalo mě to. Když o tom přede mnou pořád básnili kolegové v práci, rozhodl jsem se, že to zkusím taky.
… více »Byla vydána verze 0.5.20 open source správce počítačových her na Linuxu Lutris (Wikipedie). Přehled novinek v oznámení na GitHubu. Instalovat lze také z Flathubu.
Peter Steinberger, autor open source AI asistenta OpenClaw, nastupuje do OpenAI. OpenClaw bude převeden pod nadaci a zůstane otevřený a nezávislý.
Čau, snažím se rozjet v code:block tento kód:
#define GLEW_STATIC
#include <GL/glew.h>
#include <GL/glut.h>
#include <stdlib.h>
#include <stdio.h>
// nekdy je potreba pouzivat funkce s priponou ARB...
#ifdef USE_ARB
#define glBindBuffer glBindBufferARB
#define glGenBuffers glGenBuffersARB
#define glBufferData glBufferDataARB
#define glBufferSubData glBufferSubDataARB
#define glDeleteBuffers glDeleteBuffersARB
#endif
/*
Priklad na Vertex Buffer Objects
================================
Oproti predchozimu (Vertex Arrays) je toto prvni metoda, ktera
nahrava objekty primo do pameti graficke karty, diky cemuz pak
neni nutne pri kazdem kresleni prenaset nejaka vetsi data mezi
programem a grafickou kartou.
Princip:
1) V inicializaci vytvorim VBO a do neho nahraju vsechna data,
ta pak mohu smazat z uzivatelske pameti
2) Lze tam kombinovat souradnice i barvy i dalsi veci
3) Pri kresleni je potreba zabindovat patricny buffer - ten se
identifikuje pouze integerem
4) Dale je treba nastavit ukazatele, pokazde znova
5) Pole lze delat prokladane nebo to davat kamkoliv, predavaji
se tam ukazatele
6) Kreslime to stejnym prikazem jako VertexArrays, to je totiz
asi uplne jedno, ty funkce budou pretizene a akorat berou data
z jineho zdroje
*/
// identifikator bufferu, mimo funkce staci jen toto
GLuint vbo_id;
void init(void)
{
glClearColor (0.0, 0.0, 0.0, 0.0);
glClearDepth(1.0);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
gluOrtho2D(0, 800, 0, 600);
// v initu je nyni potreba vytvorit VBO a nahrat do nej data,
// cimzto se data nahraji do graficke karty a z uzivatelske
// pameti mohou byt vymazana
// (kolik_bufferu_chci, ukazatel_kam_zapsat_vznikle_id)
glGenBuffers(1, &vbo_id);
printf("get error = %i\n", glGetError());
// tato data jsou pouze lokalni na zasobniku, pak je mozne je
// smazat...
static GLfloat triangles[] =
{
0.0, 0.0, 1.0, 0.0, 0.0,
200.0, 200.0, 1.0, 1.0, 0.0,
0.0, 200.0, 0.0, 1.0, 1.0,
300.0, 300.0, 1.0, 0.0, 0.0,
600.0, 500.0, 0.0, 0.0, 1.0,
300.0, 450.0, 1.0, 0.0, 1.0
};
// jdem nahrat data do bufferu
glBindBuffer(GL_ARRAY_BUFFER, vbo_id);
glBufferData(GL_ARRAY_BUFFER, sizeof(triangles), triangles, GL_STATIC_DRAW);
// dalsi funkce je pro pripadne dalsi data
// glBufferSubData(GL_ARRAY_BUFFER, 0, sizeof(triangles), triangles);
// BYLO BY FAJN v nejakem destruktoru volat funkci glDeleteBuffers,
// ale to tady v tomto priklade neni... glutMainLoop uz neskonci, ale
// pri ukoncovani programu by se mely volat napr. destruktory sceny, takze
// pokud mame nejakou statickou scenu, tak muzeme uklid dat tam... dalsi
// varianta je UDAJNE registrace callbacku atexit(func_to_be_called) u
// ostatnich callbacku
}
void onDisplay(void)
{
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
// tady se to musi zapnout
glEnableClientState(GL_VERTEX_ARRAY);
glEnableClientState(GL_COLOR_ARRAY);
// zabindujeme buffer, nutno delat pred kazdym kreslenim
glBindBuffer(GL_ARRAY_BUFFER, vbo_id);
// nastavime pointery... TENTOKRAT MAME NA KONCI INT pouze pretypovany na void *
// --> takze to nikam neukazuje, je to jen index
glVertexPointer(2, GL_FLOAT, 5 * sizeof(GLfloat), (GLvoid *) 0);
glColorPointer(3, GL_FLOAT, 5 * sizeof(GLfloat), (void *) (2 * sizeof(GL_FLOAT)));
// vykreslime VBO
glDrawArrays(GL_TRIANGLES, 0, 6);
// vypnem to
glDisableClientState(GL_VERTEX_ARRAY);
glDisableClientState(GL_COLOR_ARRAY);
// zapiseme zmeny
glFlush();
}
void onReshape (int w, int h)
{
glViewport (0, 0, (GLsizei) w, (GLsizei) h);
}
void onKeyboard(unsigned char key, int x, int y)
{
switch (key) {
case 27:
exit(0);
break;
}
glutPostRedisplay();
}
int main(int argc, char** argv)
{
glutInit(&argc, argv);
glutInitDisplayMode (GLUT_SINGLE | GLUT_RGBA | GLUT_DEPTH);
glutInitWindowSize (800, 600);
glutInitWindowPosition (100, 100);
glutCreateWindow ("Polopaticky mustr na Vertex Buffer Objects");
GLenum err = glewInit();
init ();
glutDisplayFunc(onDisplay);
glutReshapeFunc(onReshape);
glutKeyboardFunc(onKeyboard);
glutMainLoop();
return 0;
}
Mám v systému tyto balíčky:
freeglut3 freeglut3-dev libglew1.5 libglew1.5-dev libglu1-mesa libglu1-mesa-dev libgl1-mesa-glx libgl1-mesa-dev
A stále mi to háže chyby kterým nerozumím. Viz příloha.
Tuší někdo kde mám chybu?
Díky Dan
Pro úspěšné vytvoření binárky jí musíš slinkovat s knihovnami libglut.so a libGLEW.so:
$ gcc -lglut -lGLEW -o test test.c
/usr bylo správně (pokud ovšem v usr jsou podadresáře include a lib a tam jsou ty .h a .a,.so).
Tiskni
Sdílej: