亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ftgrays.c

?? 智能設(shè)備中PDF閱讀器的源碼!用于windows mobile2003或者WM5以上
?? C
?? 第 1 頁 / 共 4 頁
字號:
      v_start = outline->points[first];
      v_last  = outline->points[last];

      v_start.x = SCALED( v_start.x ); v_start.y = SCALED( v_start.y );
      v_last.x  = SCALED( v_last.x );  v_last.y  = SCALED( v_last.y );

      v_control = v_start;

      point = outline->points + first;
      tags  = outline->tags  + first;
      tag   = FT_CURVE_TAG( tags[0] );

      /* A contour cannot start with a cubic control point! */
      if ( tag == FT_CURVE_TAG_CUBIC )
        goto Invalid_Outline;

      /* check first point to determine origin */
      if ( tag == FT_CURVE_TAG_CONIC )
      {
        /* first point is conic control.  Yes, this happens. */
        if ( FT_CURVE_TAG( outline->tags[last] ) == FT_CURVE_TAG_ON )
        {
          /* start at last point if it is on the curve */
          v_start = v_last;
          limit--;
        }
        else
        {
          /* if both first and last points are conic,         */
          /* start at their middle and record its position    */
          /* for closure                                      */
          v_start.x = ( v_start.x + v_last.x ) / 2;
          v_start.y = ( v_start.y + v_last.y ) / 2;

          v_last = v_start;
        }
        point--;
        tags--;
      }

      error = func_interface->move_to( &v_start, user );
      if ( error )
        goto Exit;

      while ( point < limit )
      {
        point++;
        tags++;

        tag = FT_CURVE_TAG( tags[0] );
        switch ( tag )
        {
        case FT_CURVE_TAG_ON:  /* emit a single line_to */
          {
            FT_Vector  vec;


            vec.x = SCALED( point->x );
            vec.y = SCALED( point->y );

            error = func_interface->line_to( &vec, user );
            if ( error )
              goto Exit;
            continue;
          }

        case FT_CURVE_TAG_CONIC:  /* consume conic arcs */
          {
            v_control.x = SCALED( point->x );
            v_control.y = SCALED( point->y );

          Do_Conic:
            if ( point < limit )
            {
              FT_Vector  vec;
              FT_Vector  v_middle;


              point++;
              tags++;
              tag = FT_CURVE_TAG( tags[0] );

              vec.x = SCALED( point->x );
              vec.y = SCALED( point->y );

              if ( tag == FT_CURVE_TAG_ON )
              {
                error = func_interface->conic_to( &v_control, &vec, user );
                if ( error )
                  goto Exit;
                continue;
              }

              if ( tag != FT_CURVE_TAG_CONIC )
                goto Invalid_Outline;

              v_middle.x = ( v_control.x + vec.x ) / 2;
              v_middle.y = ( v_control.y + vec.y ) / 2;

              error = func_interface->conic_to( &v_control, &v_middle, user );
              if ( error )
                goto Exit;

              v_control = vec;
              goto Do_Conic;
            }

            error = func_interface->conic_to( &v_control, &v_start, user );
            goto Close;
          }

        default:  /* FT_CURVE_TAG_CUBIC */
          {
            FT_Vector  vec1, vec2;


            if ( point + 1 > limit                             ||
                 FT_CURVE_TAG( tags[1] ) != FT_CURVE_TAG_CUBIC )
              goto Invalid_Outline;

            point += 2;
            tags  += 2;

            vec1.x = SCALED( point[-2].x ); vec1.y = SCALED( point[-2].y );
            vec2.x = SCALED( point[-1].x ); vec2.y = SCALED( point[-1].y );

            if ( point <= limit )
            {
              FT_Vector  vec;


              vec.x = SCALED( point->x );
              vec.y = SCALED( point->y );

              error = func_interface->cubic_to( &vec1, &vec2, &vec, user );
              if ( error )
                goto Exit;
              continue;
            }

            error = func_interface->cubic_to( &vec1, &vec2, &v_start, user );
            goto Close;
          }
        }
      }

      /* close the contour with a line segment */
      error = func_interface->line_to( &v_start, user );

   Close:
      if ( error )
        goto Exit;

      first = last + 1;
    }

    return 0;

  Exit:
    return error;

  Invalid_Outline:
    return ErrRaster_Invalid_Outline;
  }

#endif /* _STANDALONE_ */


  typedef struct  TBand_
  {
    TPos  min, max;

  } TBand;


  static int
  gray_convert_glyph_inner( RAS_ARG )
  {
    static
    const FT_Outline_Funcs  func_interface =
    {
      (FT_Outline_MoveTo_Func) gray_move_to,
      (FT_Outline_LineTo_Func) gray_line_to,
      (FT_Outline_ConicTo_Func)gray_conic_to,
      (FT_Outline_CubicTo_Func)gray_cubic_to,
      0,
      0
    };

    volatile int  error = 0;

    if ( ft_setjmp( ras.jump_buffer ) == 0 )
    {
      error = FT_Outline_Decompose( &ras.outline, &func_interface, &ras );
      gray_record_cell( RAS_VAR );
    }
    else
    {
      error = ErrRaster_MemoryOverflow;
    }

    return error;
  }


  static int
  gray_convert_glyph( RAS_ARG )
  {
    TBand            bands[40];
    TBand* volatile  band;
    int volatile     n, num_bands;
    TPos volatile    min, max, max_y;
    FT_BBox*         clip;


    /* Set up state in the raster object */
    gray_compute_cbox( RAS_VAR );

    /* clip to target bitmap, exit if nothing to do */
    clip = &ras.clip_box;

    if ( ras.max_ex <= clip->xMin || ras.min_ex >= clip->xMax ||
         ras.max_ey <= clip->yMin || ras.min_ey >= clip->yMax )
      return 0;

    if ( ras.min_ex < clip->xMin ) ras.min_ex = clip->xMin;
    if ( ras.min_ey < clip->yMin ) ras.min_ey = clip->yMin;

    if ( ras.max_ex > clip->xMax ) ras.max_ex = clip->xMax;
    if ( ras.max_ey > clip->yMax ) ras.max_ey = clip->yMax;

    /* simple heuristic used to speed-up the bezier decomposition -- see */
    /* the code in gray_render_conic() and gray_render_cubic() for more  */
    /* details                                                           */
    ras.conic_level = 32;
    ras.cubic_level = 16;

    {
      int level = 0;


      if ( ras.max_ex > 24 || ras.max_ey > 24 )
        level++;
      if ( ras.max_ex > 120 || ras.max_ey > 120 )
        level++;

      ras.conic_level <<= level;
      ras.cubic_level <<= level;
    }

    /* setup vertical bands */
    num_bands = (int)( ( ras.max_ey - ras.min_ey ) / ras.band_size );
    if ( num_bands == 0 )  num_bands = 1;
    if ( num_bands >= 39 ) num_bands = 39;

    ras.band_shoot = 0;

    min   = ras.min_ey;
    max_y = ras.max_ey;

    for ( n = 0; n < num_bands; n++, min = max )
    {
      max = min + ras.band_size;
      if ( n == num_bands - 1 || max > max_y )
        max = max_y;

      bands[0].min = min;
      bands[0].max = max;
      band         = bands;

      while ( band >= bands )
      {
        TPos  bottom, top, middle;
        int   error;


        ras.num_cells = 0;
        ras.invalid   = 1;
        ras.min_ey    = band->min;
        ras.max_ey    = band->max;

#if 1
        error = gray_convert_glyph_inner( RAS_VAR );
#else
        error = FT_Outline_Decompose( outline, &func_interface, &ras ) ||
                gray_record_cell( RAS_VAR );
#endif

        if ( !error )
        {
#ifdef SHELL_SORT
          gray_shell_sort( ras.cells, ras.num_cells );
#else
          gray_quick_sort( ras.cells, ras.num_cells );
#endif

#ifdef DEBUG_GRAYS
          gray_check_sort( ras.cells, ras.num_cells );
          gray_dump_cells( RAS_VAR );
#endif

          gray_sweep( RAS_VAR_  &ras.target );
          band--;
          continue;
        }
        else if ( error != ErrRaster_MemoryOverflow )
          return 1;

        /* render pool overflow, we will reduce the render band by half */
        bottom = band->min;
        top    = band->max;
        middle = bottom + ( ( top - bottom ) >> 1 );

        /* waoow! This is too complex for a single scanline, something */
        /* must be really rotten here!                                 */
        if ( middle == bottom )
        {
#ifdef DEBUG_GRAYS
          fprintf( stderr, "Rotten glyph!\n" );
#endif
          return 1;
        }

        if ( bottom-top >= ras.band_size )
          ras.band_shoot++;

        band[1].min = bottom;
        band[1].max = middle;
        band[0].min = middle;
        band[0].max = top;
        band++;
      }
    }

    if ( ras.band_shoot > 8 && ras.band_size > 16 )
      ras.band_size = ras.band_size / 2;

    return 0;
  }


  static int
  gray_raster_render( PRaster                  raster,
                      const FT_Raster_Params*  params )
  {
    const FT_Outline*  outline    = (const FT_Outline*)params->source;
    const FT_Bitmap*   target_map = params->target;


    if ( !raster || !raster->cells || !raster->max_cells )
      return -1;

    /* return immediately if the outline is empty */
    if ( outline->n_points == 0 || outline->n_contours <= 0 )
      return 0;

    if ( !outline || !outline->contours || !outline->points )
      return ErrRaster_Invalid_Outline;

    if ( outline->n_points !=
           outline->contours[outline->n_contours - 1] + 1 )
      return ErrRaster_Invalid_Outline;

    /* if direct mode is not set, we must have a target bitmap */
    if ( ( params->flags & FT_RASTER_FLAG_DIRECT ) == 0 &&
         ( !target_map || !target_map->buffer )         )
      return -1;

    /* this version does not support monochrome rendering */
    if ( !( params->flags & FT_RASTER_FLAG_AA ) )
      return ErrRaster_Invalid_Mode;

    /* compute clipping box */
    if ( ( params->flags & FT_RASTER_FLAG_DIRECT ) == 0 )
    {
      /* compute clip box from target pixmap */
      ras.clip_box.xMin = 0;
      ras.clip_box.yMin = 0;
      ras.clip_box.xMax = target_map->width;
      ras.clip_box.yMax = target_map->rows;
    }
    else if ( params->flags & FT_RASTER_FLAG_CLIP )
    {
      ras.clip_box = params->clip_box;
    }
    else
    {
      ras.clip_box.xMin = -32768L;
      ras.clip_box.yMin = -32768L;
      ras.clip_box.xMax =  32767L;
      ras.clip_box.yMax =  32767L;
    }

    ras.outline   = *outline;
    ras.num_cells = 0;
    ras.invalid   = 1;

    if ( target_map )
      ras.target = *target_map;

    ras.render_span      = (FT_Raster_Span_Func)gray_render_span;
    ras.render_span_data = &ras;

    if ( params->flags & FT_RASTER_FLAG_DIRECT )
    {
      ras.render_span      = (FT_Raster_Span_Func)params->gray_spans;
      ras.render_span_data = params->user;
    }

    return gray_convert_glyph( (PRaster)raster );
  }


  /**** RASTER OBJECT CREATION: In standalone mode, we simply use *****/
  /****                         a static object.                  *****/

#ifdef GRAYS_USE_GAMMA

  /* initialize the "gamma" table. Yes, this is really a crummy function */
  /* but the results look pretty good for something that simple.         */
  /*                                                                     */
#define M_MAX  255
#define M_X    128
#define M_Y    192

  static void
  grays_init_gamma( PRaster  raster )
  {
    unsigned int  x, a;


    for ( x = 0; x < 256; x++ )
    {
      if ( x <= M_X )
        a = ( x * M_Y + M_X / 2) / M_X;
      else
        a = M_Y + ( ( x - M_X ) * ( M_MAX - M_Y ) +
            ( M_MAX - M_X ) / 2 ) / ( M_MAX - M_X );

      raster->gamma[x] = (unsigned char)a;
    }
  }

#endif /* GRAYS_USE_GAMMA */

#ifdef _STANDALONE_

  static int
  gray_raster_new( void*       memory,
                   FT_Raster*  araster )
  {
    static TRaster  the_raster;

    FT_UNUSED( memory );


    *araster = (FT_Raster)&the_raster;
    FT_MEM_ZERO( &the_raster, sizeof ( the_raster ) );

#ifdef GRAYS_USE_GAMMA
    grays_init_gamma( (PRaster)*araster );
#endif

    return 0;
  }


  static void
  gray_raster_done( FT_Raster  raster )
  {
    /* nothing */
    FT_UNUSED( raster );
  }

#else /* _STANDALONE_ */

  static int
  gray_raster_new( FT_Memory   memory,
                   FT_Raster*  araster )
  {
    FT_Error  error;
    PRaster   raster;


    *araster = 0;
    if ( !FT_ALLOC( raster, sizeof ( TRaster ) ) )
    {
      raster->memory = memory;
      *araster = (FT_Raster)raster;

#ifdef GRAYS_USE_GAMMA
      grays_init_gamma( raster );
#endif
    }

    return error;
  }


  static void
  gray_raster_done( FT_Raster  raster )
  {
    FT_Memory  memory = (FT_Memory)((PRaster)raster)->memory;


    FT_FREE( raster );
  }

#endif /* _STANDALONE_ */


  static void
  gray_raster_reset( FT_Raster    raster,
                     char*        pool_base,
                     long         pool_size )
  {
    PRaster  rast = (PRaster)raster;


    if ( raster && pool_base && pool_size >= 4096 )
      gray_init_cells( rast, (char*)pool_base, pool_size );

    rast->band_size  = (int)( ( pool_size / sizeof ( TCell ) ) / 8 );
  }


  const FT_Raster_Funcs  ft_grays_raster =
  {
    FT_GLYPH_FORMAT_OUTLINE,

    (FT_Raster_New_Func)     gray_raster_new,
    (FT_Raster_Reset_Func)   gray_raster_reset,
    (FT_Raster_Set_Mode_Func)0,
    (FT_Raster_Render_Func)  gray_raster_render,
    (FT_Raster_Done_Func)    gray_raster_done
  };


/* END */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99精品网久久| 国产精品热久久久久夜色精品三区| 亚洲视频一区在线| av一本久道久久综合久久鬼色| 国产婷婷色一区二区三区| 成人自拍视频在线| 自拍偷拍亚洲激情| 67194成人在线观看| 免费观看在线色综合| 久久久美女艺术照精彩视频福利播放| 国产在线精品免费| 国产精品动漫网站| 欧美性淫爽ww久久久久无| 亚洲成人久久影院| 亚洲精品一区二区三区香蕉| 成人av在线观| 亚洲mv大片欧洲mv大片精品| 91精品国产免费| 国产乱一区二区| 自拍偷自拍亚洲精品播放| 欧美日本一道本| 国产精品一区一区| 亚洲美女视频在线| 欧美电视剧在线观看完整版| 国模无码大尺度一区二区三区| 国产精品嫩草影院av蜜臀| 日本久久一区二区| 美日韩黄色大片| 国产精品不卡在线| 欧美一区二区高清| 97精品久久久午夜一区二区三区 | 欧美三级电影精品| 精品在线亚洲视频| 亚洲乱码国产乱码精品精可以看| 51久久夜色精品国产麻豆| 福利视频网站一区二区三区| 亚洲超丰满肉感bbw| 国产香蕉久久精品综合网| 91搞黄在线观看| 国产一区二区久久| 亚洲一二三区不卡| 国产片一区二区三区| 欧美福利电影网| 91亚洲国产成人精品一区二三| 免费在线欧美视频| 亚洲天天做日日做天天谢日日欢| 日韩一区二区免费在线观看| 99精品久久99久久久久| 精品一区二区免费视频| 亚洲综合一区二区精品导航| 国产日韩成人精品| 日韩三级中文字幕| 欧美精品久久一区| 色一情一伦一子一伦一区| 国产成人在线观看免费网站| 日韩成人精品视频| 亚洲六月丁香色婷婷综合久久| 国产免费观看久久| 26uuuu精品一区二区| 欧美一区二区高清| 欧美精品久久久久久久多人混战| 99久久精品国产一区二区三区| 精品一区二区综合| 日本三级亚洲精品| 午夜精品福利在线| 亚洲小少妇裸体bbw| 亚洲免费观看在线观看| 中文字幕中文乱码欧美一区二区| 久久久久久久久伊人| 日韩三级av在线播放| 欧美精品一二三| 欧美日韩精品高清| 欧美丰满少妇xxxxx高潮对白| 日本韩国欧美在线| 欧美主播一区二区三区| 日本高清不卡在线观看| 色婷婷综合久久久| 色悠悠亚洲一区二区| 日本高清视频一区二区| 91久久精品国产91性色tv| 色综合久久综合网| 欧洲一区在线电影| 欧美午夜精品久久久| 欧美丝袜自拍制服另类| 欧美人妇做爰xxxⅹ性高电影| 欧美三级午夜理伦三级中视频| 欧美日韩精品一区二区三区四区| 欧美最猛性xxxxx直播| 欧美私模裸体表演在线观看| 欧美日韩成人一区二区| 日韩一区二区影院| 精品欧美乱码久久久久久1区2区| 欧美va日韩va| 国产欧美一区视频| 国产精品国产三级国产| 亚洲在线免费播放| 美腿丝袜亚洲三区| 国产在线精品免费| 波多野结衣亚洲| 欧美亚洲尤物久久| 欧美一级视频精品观看| 久久嫩草精品久久久精品| 国产精品成人一区二区三区夜夜夜| 亚洲精品视频免费观看| 日韩精品电影在线观看| 韩国v欧美v亚洲v日本v| 99精品视频在线免费观看| 欧美日韩国产综合一区二区 | 日韩欧美国产午夜精品| 欧美精品一区二区三| 国产精品乱码一区二区三区软件| 亚洲日本va午夜在线电影| 亚洲成人免费电影| 国产精品亚洲专一区二区三区| 99免费精品在线| 91麻豆精品国产自产在线 | 91精品福利在线一区二区三区 | 五月综合激情婷婷六月色窝| 久久99精品国产91久久来源| 99久久99久久精品国产片果冻 | 欧美一区永久视频免费观看| 国产三级三级三级精品8ⅰ区| 一区二区在线免费观看| 精品无人区卡一卡二卡三乱码免费卡 | 成人永久免费视频| 欧美日韩国产小视频在线观看| 精品国产91久久久久久久妲己 | 国产69精品久久久久毛片| 色综合一个色综合| 欧美精品一区二区三区视频 | 日韩午夜三级在线| 国产精品久久久久久久久免费樱桃 | 一区二区中文视频| 亚洲免费在线观看| 国产成人av一区二区三区在线| 欧美三级乱人伦电影| 中文字幕免费观看一区| 热久久免费视频| 色伊人久久综合中文字幕| 久久品道一品道久久精品| 天天影视网天天综合色在线播放| www.成人网.com| 欧美久久久久久蜜桃| 亚洲免费在线播放| heyzo一本久久综合| 国产亚洲一区二区三区四区| 日韩成人av影视| 欧美中文字幕一区二区三区| 国产精品电影一区二区三区| 国产精品一区二区久久不卡| 欧美一区二区三区四区五区| 亚洲一区在线看| 色婷婷精品久久二区二区蜜臂av| 久久久不卡网国产精品一区| 免费在线看成人av| 欧美一级片免费看| 亚洲高清一区二区三区| 欧美在线观看一二区| 亚洲欧美日韩在线| caoporen国产精品视频| 国产三级精品三级| 国产精品中文字幕一区二区三区| 欧美一级片在线| 久久av老司机精品网站导航| 欧美一区二区三区日韩| 午夜av区久久| 欧美一区二区三区系列电影| 亚洲精选免费视频| 色综合欧美在线| 伊人色综合久久天天人手人婷| 色悠悠亚洲一区二区| 亚洲综合丝袜美腿| 欧美片网站yy| 男人的天堂亚洲一区| 欧美成人a在线| 激情图片小说一区| 国产亚洲精品超碰| 9色porny自拍视频一区二区| 国产精品国产自产拍高清av| av午夜一区麻豆| 亚洲精品中文字幕乱码三区| 色婷婷久久久亚洲一区二区三区| 一区二区高清在线| 91精品婷婷国产综合久久性色| 日韩精品电影在线观看| 欧美成人vps| 成人一区二区三区| 一区二区三区免费观看| 欧美日韩中文一区| 美国欧美日韩国产在线播放| 久久精品水蜜桃av综合天堂| 大胆欧美人体老妇| 一区二区三区精品久久久| 欧美日韩高清在线| 国产一区二区三区不卡在线观看 | 亚洲欧美日本韩国| 欧美精品 日韩| 国产福利一区在线| 亚洲四区在线观看| 欧美一级xxx|