abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 16:11 | Nová verze

    Bylo oznámeno (cs) vydání Fedora Linuxu 40. Přehled novinek ve Fedora Workstation 40 a Fedora KDE 40 na stránkách Fedora Magazinu. Současně byl oznámen notebook Slimbook Fedora 2.

    Ladislav Hagara | Komentářů: 3
    dnes 13:44 | Upozornění

    ČTK (Česká tisková kancelář) upozorňuje (X), že na jejím zpravodajském webu České noviny byly dnes dopoledne neznámým útočníkem umístěny dva smyšlené texty, které nepocházejí z její produkce. Jde o text s titulkem „BIS zabránila pokusu o atentát na nově zvoleného slovenského prezidenta Petra Pelligriniho“ a o údajné mimořádné prohlášení ministra Lipavského k témuž. Tyto dezinformace byly útočníky zveřejněny i s příslušnými notifikacemi v mobilní aplikaci Českých novin. ČTK ve svém zpravodajském servisu žádnou informaci v tomto znění nevydala.

    Ladislav Hagara | Komentářů: 13
    dnes 13:33 | Komunita

    Byla založena nadace Open Home Foundation zastřešující více než 240 projektů, standardů, ovladačů a knihoven (Home Assistant, ESPHome, Zigpy, Piper, Improv Wi-Fi, Wyoming, …) pro otevřenou chytrou domácnost s důrazem na soukromí, možnost výběru a udržitelnost.

    Ladislav Hagara | Komentářů: 0
    dnes 13:00 | Nová verze

    Společnost Meta otevírá svůj operační systém Meta Horizon OS pro headsety pro virtuální a rozšířenou realitu. Vedle Meta Quest se bude používat i v připravovaných headsetech od Asusu a Lenova.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | IT novinky

    Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.

    Ladislav Hagara | Komentářů: 0
    včera 23:44 | Nová verze

    Byla vydána nová stabilní verze 3.5 svobodného multiplatformního softwaru pro editování a nahrávání zvukových souborů Audacity (Wikipedie). Přehled novinek také na YouTube. Nově lze využívat cloud (audio.com). Ke stažení je oficiální AppImage. Zatím starší verze Audacity lze instalovat také z Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Zajímavý článek

    50 let operačního systému CP/M, článek na webu Computer History Museum věnovaný operačnímu systému CP/M. Gary Kildall z Digital Research jej vytvořil v roce 1974.

    Ladislav Hagara | Komentářů: 2
    včera 16:22 | Pozvánky

    Byl zveřejněn program a spuštěna registrace na letošní konferenci Prague PostgreSQL Developer Day, která se koná 4. a 5. června. Na programu jsou 4 workshopy a 8 přednášek na různá témata o PostgreSQL, od konfigurace a zálohování po využití pro AI a vector search. Stejně jako v předchozích letech se konference koná v prostorách FIT ČVUT v Praze.

    TomasVondra | Komentářů: 0
    včera 03:00 | IT novinky

    Po 48 letech Zilog končí s výrobou 8bitového mikroprocesoru Zilog Z80 (Z84C00 Z80). Mikroprocesor byl uveden na trh v červenci 1976. Poslední objednávky jsou přijímány do 14. června [pdf].

    Ladislav Hagara | Komentářů: 6
    včera 02:00 | IT novinky

    Ještě letos vyjde Kingdom Come: Deliverance II (YouTube), pokračování počítačové hry Kingdom Come: Deliverance (Wikipedie, ProtonDB Gold).

    Ladislav Hagara | Komentářů: 13
    KDE Plasma 6
     (72%)
     (10%)
     (2%)
     (17%)
    Celkem 695 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    27.2.2016 20:45 Jardík
    Rozbalit Rozbalit vše Re: Screenshot obrazovky C/C++
    Není to dokonalé, možná tam chybí někde chybové kontroly, možná je tam někde memory leak, ale nechtělo se mi s tím dělat moc dlouho. V komentáři je označeno místo, kde zpracovat výsledná data.
    #include <assert.h>
    #include <errno.h>
    #include <limits.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <xcb/xcb.h>
    #include <xcb/shm.h>
    
    #include <unistd.h>
    #include <sys/types.h>
    #include <sys/stat.h>
    #include <fcntl.h>
    
    #include <sys/ipc.h>
    #include <sys/shm.h>
    
    
    enum {
        SCR_ERR_OK,
        SCR_ERR_CONNECTION_FAIL,
        SCR_ERR_CONNECTION_ERR,
        SCR_ERR_INVALID_SCREEN,
        SCR_ERR_SHM_NOT_SUPPORTED,
        SCR_ERR_INVALID_VISUAL,
        SCR_ERR_INVALID_PIXMAP_FORMAT,
        SCR_ERR_UNSUPPORTED_VISUAL,
        SCR_ERR_IMAGE_EMPTY,
        SCR_ERR_IMAGE_TOO_LARGE,
        
        SCR_ERR_SHMGET_FAILED,
        SCR_ERR_SHM_ATTACH_FAILED,
        SCR_ERR_GET_IMAGE_FAILED,
        SCR_ERR_GET_IMAGE_RACE_CONDITION
    };
    
    struct screenshoter
    {
        xcb_connection_t *con;
        xcb_setup_t const *setup;
        xcb_screen_t *screen;
        int screen_num;
    
        xcb_depth_t const* depth;
        xcb_visualtype_t const* visual;
        xcb_format_t const* pixformat;
    
        xcb_query_extension_reply_t const* shm_ext;
    
        xcb_shm_seg_t shm_seg;
    
        struct {
            unsigned char *data;
            size_t stride, size;
        } image;
    };
    
    int receive_screenshot(struct screenshoter *scr)
    {
        xcb_shm_get_image_cookie_t img_ck = xcb_shm_get_image(scr->con, scr->screen->root,
                0, 0, scr->screen->width_in_pixels, scr->screen->height_in_pixels,
                UINT32_MAX, XCB_IMAGE_FORMAT_XY_PIXMAP, scr->shm_seg, 0);
        xcb_generic_error_t *err = NULL;
        xcb_shm_get_image_reply_t *img_rep = xcb_shm_get_image_reply(scr->con, img_ck, &err);
        if (!img_rep) {
            if (err) free(err);
            return SCR_ERR_GET_IMAGE_FAILED;
        }
    
        if (img_rep->size != scr->image.size ||
                img_rep->visual != scr->screen->root_visual ||
                img_rep->depth != scr->depth->depth)
        {
            free(img_rep);
            return SCR_ERR_GET_IMAGE_RACE_CONDITION;
        }
    
        free(img_rep);
        return 0;
    }
    
    int create_shm_seg_and_image(struct screenshoter *scr)
    {
        // check if sreen has non-zero dimensions
        if (scr->screen->width_in_pixels == 0 ||
                scr->screen->height_in_pixels == 0)
            return SCR_ERR_IMAGE_EMPTY;
    
        // XCB doesn't run on platforms with non-8bit char, so char is 8bits
        // We only support depth, bits_per_pixel and scanline_pad that is multiple
        // of whole bytes
        //
        // NOTE: shm extension seems to return packed image data, bits_per_pixel and scanline_pad
        //       are not used
        if (scr->depth->depth % 8 != 0)
            return SCR_ERR_UNSUPPORTED_VISUAL;
    
        size_t bytes_per_pixel = scr->depth->depth / 8;
    
        // Calculate stride, first multiply width by bytes_per_pixel
        size_t stride = scr->screen->width_in_pixels;
        if (SIZE_MAX / stride < bytes_per_pixel)
            return SCR_ERR_IMAGE_TOO_LARGE;
        stride *= bytes_per_pixel;
    
        // now multiply by height, to get image size in bytes
        scr->image.stride = stride;
        if (SIZE_MAX / stride < scr->screen->height_in_pixels)
            return SCR_ERR_IMAGE_TOO_LARGE;
        scr->image.size = stride * scr->screen->height_in_pixels;
    
        int shmid = shmget(IPC_PRIVATE, scr->image.size, IPC_CREAT | 0777);
        if (shmid == -1)
            return SCR_ERR_SHMGET_FAILED;
    
        scr->image.data = shmat(shmid, NULL, 0);
        if (scr->image.data == (void*)-1) {
            shmctl(shmid, IPC_RMID, NULL);
            return SCR_ERR_SHM_ATTACH_FAILED;
        }
    
        // Generate shm segment id
        scr->shm_seg = xcb_generate_id(scr->con);
        // attach our file to it, use checked call so we can block for reply
        xcb_void_cookie_t attach_ck = xcb_shm_attach_checked(scr->con,
                scr->shm_seg, shmid, 0);
        // wait for reply
        xcb_generic_error_t *attach_err = xcb_request_check(scr->con, attach_ck);
        // we don't need shmid anymore after the request was processed by X
        shmctl(shmid, IPC_RMID, NULL);
        // check attach error
        if (attach_err) {
            free(attach_err);
            shmdt(scr->image.data);
            return SCR_ERR_SHM_ATTACH_FAILED;
        }
    
        return 0;
    }
    
    void free_shm_seg_and_image(struct screenshoter *scr)
    {
        xcb_shm_detach(scr->con, scr->shm_seg);
        shmdt(scr->image.data);
    }
    
    int find_default_screen(struct screenshoter *scr)
    {
        if (scr->screen_num < 0)
            return SCR_ERR_INVALID_SCREEN;
        
        xcb_screen_iterator_t iter = xcb_setup_roots_iterator(scr->setup);
        for (int i = 0; i < scr->screen_num; ++i) {
            if (iter.rem == 0)
                return SCR_ERR_INVALID_SCREEN;
            xcb_screen_next(&iter);
        }
        scr->screen = iter.data;
        return 0;
    }
    
    int detect_root_visual(struct screenshoter *scr)
    {
        xcb_depth_iterator_t depth_iter = xcb_screen_allowed_depths_iterator(scr->screen);
        for (;;) {
            xcb_depth_t const *depth = depth_iter.data;
            int visuals_len = xcb_depth_visuals_length(depth);
            if (visuals_len <= 0)
                break;
            xcb_visualtype_t const *visuals = xcb_depth_visuals(depth);
    
            for (int i = 0; i < visuals_len; ++i) {
                if (visuals[i].visual_id == scr->screen->root_visual) {
                    scr->depth = depth;
                    scr->visual = &visuals[i];
                    return 0;
                }
            }
    
            if (depth_iter.rem == 0)
                break;
            xcb_depth_next(&depth_iter);
        }
    
        return SCR_ERR_INVALID_VISUAL;
    }
    
    int detect_pixmap_format(struct screenshoter *scr)
    {
        int formats_len = xcb_setup_pixmap_formats_length(scr->setup);
        if (formats_len > 0) {
            xcb_format_t const *formats = xcb_setup_pixmap_formats(scr->setup);
            for (int i = 0; i < formats_len; ++i) {
                if (formats[i].depth == scr->depth->depth) {
                    scr->pixformat = &formats[i];
                    return 0;
                }
            }
        }
        return SCR_ERR_INVALID_PIXMAP_FORMAT;
    }
    
    int get_screenshot(void)
    {
        struct screenshoter scr;
        int err = 0;
    
        // connect
        scr.con = xcb_connect(NULL, &scr.screen_num);
        if (!scr.con)
            return SCR_ERR_CONNECTION_FAIL;
    
        // check errors
        if (xcb_connection_has_error(scr.con)) {
            err = SCR_ERR_CONNECTION_ERR;
            goto retDisconnect;
        }
    
        // get setup and prefetch shm extension
        scr.setup = xcb_get_setup(scr.con);
        xcb_prefetch_extension_data(scr.con, &xcb_shm_id);
        xcb_flush(scr.con);
    
        // find screen
        err = find_default_screen(&scr);
        if (err != 0)
            goto retDisconnect;
    
        // detect visual
        err = detect_root_visual(&scr);
        if (err != 0)
            goto retDisconnect;
    
        // and pixmap format for root depth
        err = detect_pixmap_format(&scr);
        if (err != 0)
            goto retDisconnect;
    
        // get shm extension
        scr.shm_ext = xcb_get_extension_data(scr.con, &xcb_shm_id);
        if (!scr.shm_ext->present) {
            err = SCR_ERR_SHM_NOT_SUPPORTED;
            goto retDisconnect;
        }
    
        // create shm segment
        err = create_shm_seg_and_image(&scr);
        if (err != 0)
            goto retDisconnect;
    
        err = receive_screenshot(&scr);
        if (err == 0) {
            // TODO: process image data here
    
            // Image data is in scr.image.data, its bytesize is in scr.image.size,
            // its stride bytesize is in scr.image.stride, its width is in
            // scr.screen->width_in_pixels, height in scr.screen->height_in_pixels,
            // depth (in bits) is in scr.depth->depth. Visual format is in
            // scr.visual (red_mask, green_mask, blue_mask). Image data byteorder is
            // in scr.setup->image_byte_order
        }
    
        free_shm_seg_and_image(&scr);
        xcb_flush(scr.con);
    retDisconnect:
        xcb_disconnect(scr.con);
        return err;
    }
    
    
    int main()
    {
        int err = get_screenshot();
        fprintf(stderr, "err = %d\n", err);
    
        return 0;
    }
    
    

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.