⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 generic.c

📁 DirectFB的源码包:用于图形加速和应用开发的好东东,而且是稳定版本的,已经有应用在嵌入式平台的先例,比如NXP平台.
💻 C
📖 第 1 页 / 共 5 页
字号:
     NULL,                    /* DSPF_A4 */     Bop_rgb18_SKto_Aop,      /* DSPF_ARGB1666 */     Bop_rgb18_SKto_Aop,      /* DSPF_ARGB6666 */     Bop_rgb18_SKto_Aop,      /* DSPF_RGB18 */};/********************************* Bop_PFI_StoK_Aop_PFI ***********************/static GenefxFunc Bop_PFI_StoK_Aop_PFI[DFB_NUM_PIXELFORMATS] = {     Bop_15_StoK_Aop,         /* DSPF_ARGB1555 */     Bop_16_StoK_Aop,         /* DSPF_RGB16 */     NULL,                    /* DSPF_RGB24 */     Bop_32_StoK_Aop,         /* DSPF_RGB32 */     Bop_32_StoK_Aop,         /* DSPF_ARGB */     NULL,                    /* DSPF_A8 */     NULL,                    /* DSPF_YUY2 */     NULL,                    /* DSPF_RGB332 */     NULL,                    /* DSPF_UYVY */     NULL,                    /* DSPF_I420 */     NULL,                    /* DSPF_YV12 */     NULL,                    /* DSPF_LUT8 */     NULL,                    /* DSPF_ALUT44 */     Bop_32_StoK_Aop,         /* DSPF_AiRGB */     NULL,                    /* DSPF_A1 */     NULL,                    /* DSPF_NV12 */     NULL,                    /* DSPF_NV16 */     Bop_14_StoK_Aop,         /* DSPF_ARGB2554 */     Bop_12_StoK_Aop,         /* DSPF_ARGB4444 */     NULL,                    /* DSPF_NV21 */     NULL,                    /* DSPF_AYUV */     NULL,                    /* DSPF_A4 */     NULL,                    /* DSPF_ARGB1666 */     NULL,                    /* DSPF_ARGB6666 */     NULL,                    /* DSPF_RGB18 */};/********************************* Bop_PFI_SKtoK_Aop_PFI **********************/static GenefxFunc Bop_PFI_SKtoK_Aop_PFI[DFB_NUM_PIXELFORMATS] = {     Bop_15_SKtoK_Aop,        /* DSPF_ARGB1555 */     Bop_16_SKtoK_Aop,        /* DSPF_RGB16 */     NULL,                    /* DSPF_RGB24 */     Bop_32_SKtoK_Aop,        /* DSPF_RGB32 */     Bop_32_SKtoK_Aop,        /* DSPF_ARGB */     NULL,                    /* DSPF_A8 */     NULL,                    /* DSPF_YUY2 */     NULL,                    /* DSPF_RGB332 */     NULL,                    /* DSPF_UYVY */     NULL,                    /* DSPF_I420 */     NULL,                    /* DSPF_YV12 */     NULL,                    /* DSPF_LUT8 */     NULL,                    /* DSPF_ALUT44 */     Bop_32_SKtoK_Aop,        /* DSPF_AiRGB */     NULL,                    /* DSPF_A1 */     NULL,                    /* DSPF_NV12 */     NULL,                    /* DSPF_NV16 */     Bop_14_SKtoK_Aop,        /* DSPF_ARGB2554 */     Bop_12_SKtoK_Aop,        /* DSPF_ARGB4444 */     NULL,                    /* DSPF_NV21 */     NULL,                    /* DSPF_AYUV */     NULL,                    /* DSPF_A4 */     NULL,                    /* DSPF_ARGB1666 */     NULL,                    /* DSPF_ARGB6666 */     NULL,                    /* DSPF_RGB18 */};/********************************* Sop_PFI_Sto_Dacc ***************************/static void Sop_argb6666_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u8                *S = gfxs->Sop[0];     while (w--) {          int pixelstart = (i>>16)*3;          u8 b = S[pixelstart+0] & 0x3F;          u8 g = ((S[pixelstart+0] & 0xC0) >> 6) | ((S[pixelstart+1] & 0x0F) << 2);          u8 r = ((S[pixelstart+1] & 0xF0) >> 4) | ((S[pixelstart+2] & 0x03) << 4);          u8 a = (S[pixelstart+2] & 0xFC) >> 2;          D->RGB.a = EXPAND_6to8( a );          D->RGB.r = EXPAND_6to8( r );          D->RGB.g = EXPAND_6to8( g );          D->RGB.b = EXPAND_6to8( b );          i += SperD;          D++;     }}  static void Sop_argb1666_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u8                *S = gfxs->Sop[0];     while (w--) {          int pixelstart = (i>>16)*3;          u8 b = S[pixelstart+0] & 0x3F;          u8 g = ((S[pixelstart+0] & 0xC0) >> 6) | ((S[pixelstart+1] & 0x0F) << 2);          u8 r = ((S[pixelstart+1] & 0xF0) >> 4) | ((S[pixelstart+2] & 0x03) << 4);          u8 a = (S[pixelstart+2] & 0x04) >> 2;          D->RGB.a = EXPAND_1to8( a );          D->RGB.r = EXPAND_6to8( r );          D->RGB.g = EXPAND_6to8( g );          D->RGB.b = EXPAND_6to8( b );          i += SperD;          D++;    }}static void Sop_rgb18_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u8                *S = gfxs->Sop[0];     while (w--) {          int pixelstart = (i>>16)*3;          u8 b = S[pixelstart+0] & 0x3F;          u8 g = ((S[pixelstart+0] & 0xC0) >> 6) | ((S[pixelstart+1] & 0x0F) << 2);          u8 r = ((S[pixelstart+1] & 0xF0) >> 4) | ((S[pixelstart+2] & 0x03) << 4);          D->RGB.a = 0xFF;          D->RGB.r = EXPAND_6to8( r );          D->RGB.g = EXPAND_6to8( g );          D->RGB.b = EXPAND_6to8( b );          i += SperD;          D++;     }}static void Sop_rgb24_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u8                *S = gfxs->Sop[0];     while (w--) {          int pixelstart = (i>>16)*3;          D->RGB.a = 0xFF;          D->RGB.r = S[pixelstart+2];          D->RGB.g = S[pixelstart+1];          D->RGB.b = S[pixelstart+0];          i += SperD;          D++;     }}static void Sop_a8_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u8                *S = gfxs->Sop[0];     while (w--) {          u8 s = S[i>>16];          D->RGB.a = s;          D->RGB.r = 0xFF;          D->RGB.g = 0xFF;          D->RGB.b = 0xFF;          i += SperD;          D++;     }}static void Sop_yuy2_Sto_Dacc( GenefxState *gfxs ){     int  w     = gfxs->length>>1;     int  i     = gfxs->Xphase;     int  SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u32               *S = gfxs->Sop[0];     while (w--) {          u32 s = S[i>>17];          D[0].YUV.a = D[1].YUV.a = 0xFF;#ifdef WORDS_BIGENDIAN          D[0].YUV.u = D[1].YUV.u = (s & 0xFF000000) >> 24;          D[0].YUV.v = D[1].YUV.v = (s & 0x0000FF00) >>  8;#else          D[0].YUV.u = D[1].YUV.u = (s & 0x0000FF00) >>  8;          D[0].YUV.v = D[1].YUV.v = (s & 0xFF000000) >> 24;#endif          D[0].YUV.y = ((u16*)S)[i>>16]         & 0x00FF;          D[1].YUV.y = ((u16*)S)[(i+SperD)>>16] & 0x00FF;          D += 2;          i += SperD << 1;     }     if (gfxs->length & 1) {          u16 s = ((u16*)S)[i>>17];          D->YUV.a = 0xFF;          D->YUV.y = s & 0xFF;          D->YUV.u = s >> 8;          D->YUV.v = 0x00;     }}static void Sop_rgb332_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u8                *S = gfxs->Sop[0];     while (w--) {          u8 s = S[i>>16];          D->RGB.a = 0xFF;          D->RGB.r = EXPAND_3to8(s >> 5);          D->RGB.g = EXPAND_3to8((s & 0x1C) >> 2);          D->RGB.b = EXPAND_2to8(s & 0x03);          i += SperD;          D++;     }}static void Sop_uyvy_Sto_Dacc( GenefxState *gfxs ){     int  w     = gfxs->length>>1;     int  i     = gfxs->Xphase;     int  SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u32               *S = gfxs->Sop[0];     while (w--) {          u32 s = S[i>>17];          D[0].YUV.a = D[1].YUV.a = 0xFF;#ifdef WORDS_BIGENDIAN          D[0].YUV.u = D[1].YUV.u = (s & 0x00FF0000) >> 16;          D[0].YUV.v = D[1].YUV.v = (s & 0x000000FF);#else          D[0].YUV.u = D[1].YUV.u = (s & 0x000000FF);          D[0].YUV.v = D[1].YUV.v = (s & 0x00FF0000) >> 16;#endif          D[0].YUV.y = (((u16*)S)[i>>16]         & 0xFF00) >> 8;          D[1].YUV.y = (((u16*)S)[(i+SperD)>>16] & 0xFF00) >> 8;          D += 2;          i += SperD << 1;     }     if (gfxs->length & 1) {          u16 s = ((u16*)S)[i>>16];          D->YUV.a = 0xFF;          D->YUV.y = s >> 8;          D->YUV.u = s & 0xFF;          D->YUV.v = 0x00;     }}static void Sop_lut8_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u8                *S = gfxs->Sop[0];     DFBColor *entries = gfxs->Slut->entries;     while (w--) {          u8 s = S[i>>16];          D->RGB.a = entries[s].a;          D->RGB.r = entries[s].r;          D->RGB.g = entries[s].g;          D->RGB.b = entries[s].b;          i += SperD;          D++;     }}static void Sop_alut44_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u8                *S = gfxs->Sop[0];     DFBColor *entries = gfxs->Slut->entries;     while (w--) {          u8 s = S[i>>16];          D->RGB.a = s & 0xF0;          s &= 0x0F;          D->RGB.r = entries[s].r;          D->RGB.g = entries[s].g;          D->RGB.b = entries[s].b;          i += SperD;          D++;     }}static void Sop_i420_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D  = gfxs->Dacc;     u8                *Sy = gfxs->Sop[0];     u8                *Su = gfxs->Sop[1];     u8                *Sv = gfxs->Sop[2];     while (w--) {          D->YUV.a = 0xFF;          D->YUV.y = Sy[i>>16];          D->YUV.u = Su[i>>17];          D->YUV.v = Sv[i>>17];                    i += SperD;                    D++;     }}static void Sop_nv12_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D   = gfxs->Dacc;     u8                *Sy  = gfxs->Sop[0];     u16               *Suv = gfxs->Sop[1];          while (w--) {          D->YUV.a = 0xFF;          D->YUV.y = Sy[i>>16];          D->YUV.u = Suv[i>>17] & 0xFF;          D->YUV.v = Suv[i>>17] >> 8;                    i += SperD;                    D++;     }} static void Sop_nv21_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D   = gfxs->Dacc;     u8                *Sy  = gfxs->Sop[0];     u16               *Svu = gfxs->Sop[1];          while (w--) {          D->YUV.a = 0xFF;          D->YUV.y = Sy[i>>16];          D->YUV.u = Svu[i>>17] >> 8;          D->YUV.v = Svu[i>>17] & 0xFF;                    i += SperD;                    D++;     }}static void Sop_ayuv_Sto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     GenefxAccumulator *D = gfxs->Dacc;     u32               *S = gfxs->Sop[0];     while (w--) {          u32 s = S[i>>16];                    D->YUV.a = (s >> 24);          D->YUV.y = (s >> 16) & 0xff;          D->YUV.u = (s >>  8) & 0xff;          D->YUV.v = (s      ) & 0xff;          i += SperD;                    D++;     }}static GenefxFunc Sop_PFI_Sto_Dacc[DFB_NUM_PIXELFORMATS] = {     Sop_argb1555_Sto_Dacc,        /* DSPF_ARGB1555 */     Sop_rgb16_Sto_Dacc,           /* DSPF_RGB16 */     Sop_rgb24_Sto_Dacc,           /* DSPF_RGB24 */     Sop_rgb32_Sto_Dacc,           /* DSPF_RGB32 */     Sop_argb_Sto_Dacc,            /* DSPF_ARGB */     Sop_a8_Sto_Dacc,              /* DSPF_A8 */     Sop_yuy2_Sto_Dacc,            /* DSPF_YUY2 */     Sop_rgb332_Sto_Dacc,          /* DSPF_RGB332 */     Sop_uyvy_Sto_Dacc,            /* DSPF_UYVY */     Sop_i420_Sto_Dacc,            /* DSPF_I420 */     Sop_i420_Sto_Dacc,            /* DSPF_YV12 */     Sop_lut8_Sto_Dacc,            /* DSPF_LUT8 */     Sop_alut44_Sto_Dacc,          /* DSPF_ALUT44 */     Sop_airgb_Sto_Dacc,           /* DSPF_AiRGB */     NULL,                         /* DSPF_A1 */     Sop_nv12_Sto_Dacc,            /* DSPF_NV12 */     Sop_nv12_Sto_Dacc,            /* DSPF_NV16 */     Sop_argb2554_Sto_Dacc,        /* DSPF_ARGB2554 */     Sop_argb4444_Sto_Dacc,        /* DSPF_ARGB4444 */     Sop_nv21_Sto_Dacc,            /* DSPF_NV21 */     Sop_ayuv_Sto_Dacc,            /* DSPF_AYUV */     NULL,                         /* DSPF_A4 */     Sop_argb1666_Sto_Dacc,        /* DSPF_ARGB1666 */     Sop_argb6666_Sto_Dacc,        /* DSPF_ARGB6666 */     Sop_rgb18_Sto_Dacc,           /* DSPF_RGB18 */};/********************************* Sop_PFI_SKto_Dacc **************************/static void Sop_argb6666_SKto_Dacc( GenefxState *gfxs ){     int w     = gfxs->length;     int i     = gfxs->Xphase;     int SperD = gfxs->SperD;     u32 Skey = gfxs->Skey;     GenefxAccumulator *D = gfxs->Dacc;     u8                *S = gfxs->Sop[0];     while (w--) {          int pixelstart = (i>>16)*3;          u8 s0 = S[pixelstart+0];          u8 s1 = S[pixelstart+1];          u8 s2 = S[pixelstart+2];          if (Skey != ((u32)(s2<<16 | s1<<8 | s0) & 0x3FFFF)) {               u8 b = s0 & 0x3F;               u8 g = ((s0 & 0xC0) >> 6) | ((s1 & 0x0F) << 2);               u8 r = ((s1 & 0xF0) >> 4) | ((s2 & 0x03) << 4);               u8 a = (s2 & 0xFC) >> 2;               D->RGB.a = EXPAND_6to8( a );               D->RGB.r = EXPAND_6to8( r );               D->RGB.g = EXPAND_6to8( g );               D->RGB.b = EXPAND_6to8( b );          }          else               D->RGB.a = 0xFF00;          i += SperD;          D++;     }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -