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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ftsmooth.c

?? QT 開發環境里面一個很重要的文件
?? C
字號:
/***************************************************************************//*                                                                         *//*  ftsmooth.c                                                             *//*                                                                         *//*    Anti-aliasing renderer interface (body).                             *//*                                                                         *//*  Copyright 2000-2001, 2002, 2003, 2004, 2005 by                         *//*  David Turner, Robert Wilhelm, and Werner Lemberg.                      *//*                                                                         *//*  This file is part of the FreeType project, and may only be used,       *//*  modified, and distributed under the terms of the FreeType project      *//*  license, LICENSE.TXT.  By continuing to use, modify, or distribute     *//*  this file you indicate that you have read the license and              *//*  understand and accept it fully.                                        *//*                                                                         *//***************************************************************************/#include <ft2build.h>#include FT_INTERNAL_OBJECTS_H#include FT_OUTLINE_H#include "ftsmooth.h"#include "ftgrays.h"#include "ftsmerrs.h"  /* initialize renderer -- init its raster */  static FT_Error  ft_smooth_init( FT_Renderer  render )  {    FT_Library  library = FT_MODULE_LIBRARY( render );    render->clazz->raster_class->raster_reset( render->raster,                                               library->raster_pool,                                               library->raster_pool_size );    return 0;  }  /* sets render-specific mode */  static FT_Error  ft_smooth_set_mode( FT_Renderer  render,                      FT_ULong     mode_tag,                      FT_Pointer   data )  {    /* we simply pass it to the raster */    return render->clazz->raster_class->raster_set_mode( render->raster,                                                         mode_tag,                                                         data );  }  /* transform a given glyph image */  static FT_Error  ft_smooth_transform( FT_Renderer       render,                       FT_GlyphSlot      slot,                       const FT_Matrix*  matrix,                       const FT_Vector*  delta )  {    FT_Error  error = Smooth_Err_Ok;    if ( slot->format != render->glyph_format )    {      error = Smooth_Err_Invalid_Argument;      goto Exit;    }    if ( matrix )      FT_Outline_Transform( &slot->outline, matrix );    if ( delta )      FT_Outline_Translate( &slot->outline, delta->x, delta->y );  Exit:    return error;  }  /* return the glyph's control box */  static void  ft_smooth_get_cbox( FT_Renderer   render,                      FT_GlyphSlot  slot,                      FT_BBox*      cbox )  {    FT_MEM_ZERO( cbox, sizeof ( *cbox ) );    if ( slot->format == render->glyph_format )      FT_Outline_Get_CBox( &slot->outline, cbox );  }  /* convert a slot's glyph image into a bitmap */  static FT_Error  ft_smooth_render_generic( FT_Renderer       render,                            FT_GlyphSlot      slot,                            FT_Render_Mode    mode,                            const FT_Vector*  origin,                            FT_Render_Mode    required_mode,                            FT_Int            hmul,                            FT_Int            vmul )  {    FT_Error     error;    FT_Outline*  outline = NULL;    FT_BBox      cbox;    FT_UInt      width, height, pitch;    FT_Bitmap*   bitmap;    FT_Memory    memory;    FT_Raster_Params  params;    /* check glyph image format */    if ( slot->format != render->glyph_format )    {      error = Smooth_Err_Invalid_Argument;      goto Exit;    }    /* check mode */    if ( mode != required_mode )      return Smooth_Err_Cannot_Render_Glyph;    outline = &slot->outline;    /* translate the outline to the new origin if needed */    if ( origin )      FT_Outline_Translate( outline, origin->x, origin->y );    /* compute the control box, and grid fit it */    FT_Outline_Get_CBox( outline, &cbox );    cbox.xMin = FT_PIX_FLOOR( cbox.xMin );    cbox.yMin = FT_PIX_FLOOR( cbox.yMin );    cbox.xMax = FT_PIX_CEIL( cbox.xMax );    cbox.yMax = FT_PIX_CEIL( cbox.yMax );    width  = (FT_UInt)( ( cbox.xMax - cbox.xMin ) >> 6 );    height = (FT_UInt)( ( cbox.yMax - cbox.yMin ) >> 6 );    bitmap = &slot->bitmap;    memory = render->root.memory;    /* release old bitmap buffer */    if ( slot->internal->flags & FT_GLYPH_OWN_BITMAP )    {      FT_FREE( bitmap->buffer );      slot->internal->flags &= ~FT_GLYPH_OWN_BITMAP;    }    /* allocate new one, depends on pixel format */    pitch = width;    if ( hmul )    {      width = width * hmul;      pitch = FT_PAD_CEIL( width, 4 );    }    if ( vmul )      height *= vmul;    bitmap->pixel_mode = FT_PIXEL_MODE_GRAY;    bitmap->num_grays  = 256;    bitmap->width      = width;    bitmap->rows       = height;    bitmap->pitch      = pitch;    if ( FT_ALLOC( bitmap->buffer, (FT_ULong)pitch * height ) )      goto Exit;    slot->internal->flags |= FT_GLYPH_OWN_BITMAP;    /* translate outline to render it into the bitmap */    FT_Outline_Translate( outline, -cbox.xMin, -cbox.yMin );    /* set up parameters */    params.target = bitmap;    params.source = outline;    params.flags  = FT_RASTER_FLAG_AA;    /* implode outline if needed */    {      FT_Int      n;      FT_Vector*  vec;      if ( hmul )        for ( vec = outline->points, n = 0; n < outline->n_points; n++, vec++ )          vec->x *= hmul;      if ( vmul )        for ( vec = outline->points, n = 0; n < outline->n_points; n++, vec++ )          vec->y *= vmul;    }    /* render outline into the bitmap */    error = render->raster_render( render->raster, &params );    /* deflate outline if needed */    {      FT_Int      n;      FT_Vector*  vec;      if ( hmul )        for ( vec = outline->points, n = 0; n < outline->n_points; n++, vec++ )          vec->x /= hmul;      if ( vmul )        for ( vec = outline->points, n = 0; n < outline->n_points; n++, vec++ )          vec->y /= vmul;    }    FT_Outline_Translate( outline, cbox.xMin, cbox.yMin );    if ( error )      goto Exit;    slot->format      = FT_GLYPH_FORMAT_BITMAP;    slot->bitmap_left = (FT_Int)( cbox.xMin >> 6 );    slot->bitmap_top  = (FT_Int)( cbox.yMax >> 6 );  Exit:    if ( outline && origin )      FT_Outline_Translate( outline, -origin->x, -origin->y );    return error;  }  /* convert a slot's glyph image into a bitmap */  static FT_Error  ft_smooth_render( FT_Renderer       render,                    FT_GlyphSlot      slot,                    FT_Render_Mode    mode,                    const FT_Vector*  origin )  {    if ( mode == FT_RENDER_MODE_LIGHT )      mode = FT_RENDER_MODE_NORMAL;    return ft_smooth_render_generic( render, slot, mode, origin,                                     FT_RENDER_MODE_NORMAL,                                     0, 0 );  }  /* convert a slot's glyph image into a horizontal LCD bitmap */  static FT_Error  ft_smooth_render_lcd( FT_Renderer       render,                        FT_GlyphSlot      slot,                        FT_Render_Mode    mode,                        const FT_Vector*  origin )  {    FT_Error  error;    error = ft_smooth_render_generic( render, slot, mode, origin,                                      FT_RENDER_MODE_LCD,                                      3, 0 );    if ( !error )      slot->bitmap.pixel_mode = FT_PIXEL_MODE_LCD;    return error;  }  /* convert a slot's glyph image into a vertical LCD bitmap */  static FT_Error  ft_smooth_render_lcd_v( FT_Renderer       render,                          FT_GlyphSlot      slot,                          FT_Render_Mode    mode,                          const FT_Vector*  origin )  {    FT_Error  error;    error = ft_smooth_render_generic( render, slot, mode, origin,                                      FT_RENDER_MODE_LCD_V,                                      0, 3 );    if ( !error )      slot->bitmap.pixel_mode = FT_PIXEL_MODE_LCD_V;    return error;  }  FT_CALLBACK_TABLE_DEF  const FT_Renderer_Class  ft_smooth_renderer_class =  {    {      FT_MODULE_RENDERER,      sizeof( FT_RendererRec ),      "smooth",      0x10000L,      0x20000L,      0,    /* module specific interface */      (FT_Module_Constructor)ft_smooth_init,      (FT_Module_Destructor) 0,      (FT_Module_Requester)  0    },    FT_GLYPH_FORMAT_OUTLINE,    (FT_Renderer_RenderFunc)   ft_smooth_render,    (FT_Renderer_TransformFunc)ft_smooth_transform,    (FT_Renderer_GetCBoxFunc)  ft_smooth_get_cbox,    (FT_Renderer_SetModeFunc)  ft_smooth_set_mode,    (FT_Raster_Funcs*)    &ft_grays_raster  };  FT_CALLBACK_TABLE_DEF  const FT_Renderer_Class  ft_smooth_lcd_renderer_class =  {    {      FT_MODULE_RENDERER,      sizeof( FT_RendererRec ),      "smooth-lcd",      0x10000L,      0x20000L,      0,    /* module specific interface */      (FT_Module_Constructor)ft_smooth_init,      (FT_Module_Destructor) 0,      (FT_Module_Requester)  0    },    FT_GLYPH_FORMAT_OUTLINE,    (FT_Renderer_RenderFunc)   ft_smooth_render_lcd,    (FT_Renderer_TransformFunc)ft_smooth_transform,    (FT_Renderer_GetCBoxFunc)  ft_smooth_get_cbox,    (FT_Renderer_SetModeFunc)  ft_smooth_set_mode,    (FT_Raster_Funcs*)    &ft_grays_raster  };  FT_CALLBACK_TABLE_DEF  const FT_Renderer_Class  ft_smooth_lcdv_renderer_class =  {    {      FT_MODULE_RENDERER,      sizeof( FT_RendererRec ),      "smooth-lcdv",      0x10000L,      0x20000L,      0,    /* module specific interface */      (FT_Module_Constructor)ft_smooth_init,      (FT_Module_Destructor) 0,      (FT_Module_Requester)  0    },    FT_GLYPH_FORMAT_OUTLINE,    (FT_Renderer_RenderFunc)   ft_smooth_render_lcd_v,    (FT_Renderer_TransformFunc)ft_smooth_transform,    (FT_Renderer_GetCBoxFunc)  ft_smooth_get_cbox,    (FT_Renderer_SetModeFunc)  ft_smooth_set_mode,    (FT_Raster_Funcs*)    &ft_grays_raster  };/* END */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费高清不卡av| 欧美一区二区福利在线| 日韩一级免费观看| 天天操天天色综合| 91豆麻精品91久久久久久| 国产精品三级电影| 韩国av一区二区三区在线观看| 欧美精品一卡二卡| 亚洲电影一级黄| 欧美中文字幕一区二区三区| 中文字幕在线观看一区| 99久久免费视频.com| 久久久亚洲精华液精华液精华液| 奇米777欧美一区二区| 久久中文娱乐网| 国产一区二区精品久久99| 国产拍欧美日韩视频二区 | 日韩女优制服丝袜电影| 日韩精品久久久久久| 精品伦理精品一区| 国产福利电影一区二区三区| 国产精品国产三级国产普通话99 | 亚洲一区二区在线观看视频| 欧美日韩一区二区三区四区五区| 亚洲成人福利片| 欧美www视频| 一本一道波多野结衣一区二区| 亚洲国产精品综合小说图片区| 91精品国产品国语在线不卡| 国内精品国产成人国产三级粉色| 亚洲欧洲三级电影| 91精品国产欧美一区二区18| 国产黑丝在线一区二区三区| 香蕉av福利精品导航| 亚洲精品在线免费播放| 91小视频在线免费看| 奇米影视在线99精品| 亚洲精品成人天堂一二三| 欧美成人免费网站| 91麻豆精品国产91久久久更新时间| 韩国v欧美v日本v亚洲v| 亚洲成a天堂v人片| 亚洲日本电影在线| 久久久久国产精品免费免费搜索| 欧美日韩国产免费| 色悠悠久久综合| 91在线一区二区| 成人免费高清视频| 丁香另类激情小说| 国产综合久久久久久鬼色| 国产一区二区三区电影在线观看| 欧美aaaaaa午夜精品| 欧美一区二区三区免费视频| 91香蕉视频污在线| 91麻豆免费看片| av电影天堂一区二区在线| 国产1区2区3区精品美女| 国产一区二区不卡| www.日本不卡| 色综合久久88色综合天天6| 99久久免费国产| 欧美综合色免费| 欧美日韩视频在线第一区| 欧美日韩国产综合一区二区| 欧美群妇大交群中文字幕| 欧美一区午夜精品| 久久久精品tv| 亚洲欧美一区二区三区国产精品 | 欧美日韩国产天堂| 欧美一级一区二区| 国产欧美一区二区三区鸳鸯浴 | 欧美国产精品一区| 亚洲另类在线一区| 久久精品国产77777蜜臀| 国产精品一区二区久久精品爱涩| 国产呦精品一区二区三区网站| 国产中文一区二区三区| 色婷婷综合久久久久中文 | 日韩精品一区二区三区在线| 久久综合久久鬼色| 亚洲精品乱码久久久久| 极品少妇xxxx精品少妇| 91成人免费网站| 久久久精品国产免费观看同学| 一区二区三区丝袜| 国产91在线|亚洲| 精品奇米国产一区二区三区| 亚洲人成网站影音先锋播放| 国产综合久久久久久久久久久久| 91美女片黄在线观看| 欧美国产精品专区| 国产在线不卡一区| 日韩网站在线看片你懂的| 亚洲精品videosex极品| 成人精品小蝌蚪| 久久久国产午夜精品| 六月婷婷色综合| 欧美一区二区精品在线| 午夜亚洲国产au精品一区二区| av一区二区三区四区| 国产精品污www在线观看| 国产精品夜夜爽| 国产精品无码永久免费888| 成人午夜视频网站| 国产精品女同互慰在线看| 国产一区二区三区蝌蚪| 亚洲精品一线二线三线无人区| 日韩电影在线一区二区| 欧美日韩第一区日日骚| 亚洲1区2区3区4区| 91精品国产黑色紧身裤美女| 日本vs亚洲vs韩国一区三区二区| 91麻豆精品国产91久久久久 | 免费的国产精品| 欧美zozozo| 成人av电影在线网| 怡红院av一区二区三区| 欧美男男青年gay1069videost| 天堂成人国产精品一区| 久久众筹精品私拍模特| 成人av中文字幕| 青青草原综合久久大伊人精品优势| 欧美高清精品3d| 国产成人aaa| 日韩高清不卡一区| 亚洲欧美色图小说| 日韩欧美成人激情| 色妹子一区二区| 国产成人综合精品三级| 一区二区国产盗摄色噜噜| 精品久久久久久最新网址| 99久久久国产精品| 国产一区啦啦啦在线观看| 亚洲乱码国产乱码精品精可以看| 日韩一区二区免费电影| 91亚洲精华国产精华精华液| 国内精品久久久久影院色| 亚洲成av人片一区二区| 中文字幕在线一区二区三区| 91精品在线免费| 在线亚洲一区观看| 99久久er热在这里只有精品66| 久久成人综合网| 欧美成人vps| 三级成人在线视频| 久久综合色综合88| 精品美女一区二区三区| 91精品国产综合久久久久久久久久 | 欧美在线视频全部完| www.av亚洲| 色偷偷88欧美精品久久久| 色悠悠亚洲一区二区| 欧美一区二区三区在线电影| 精品久久久久久久久久久久包黑料 | 国产亚洲精品超碰| 亚洲免费在线视频一区 二区| 视频一区视频二区中文| 国产精品1区二区.| 91精品国产综合久久蜜臀 | 亚洲精品一区在线观看| 最近中文字幕一区二区三区| 亚洲va欧美va天堂v国产综合| 国产精品456| 日韩你懂的在线观看| 一区二区三区中文字幕电影 | 成人av资源下载| 欧美老肥妇做.爰bbww视频| 欧美激情一区二区| 蜜桃精品在线观看| 在线一区二区三区四区| 欧美国产日韩精品免费观看| 日韩国产精品久久久| 日本韩国精品在线| 国产精品视频一区二区三区不卡| 日韩电影一区二区三区四区| 一本大道久久a久久精品综合| 欧美精品一区二区久久婷婷| 亚洲一二三级电影| 色综合久久中文综合久久牛| 久久久久久久久伊人| 免费成人av资源网| 欧美性受xxxx黑人xyx性爽| 国产精品美女久久久久aⅴ | 国产欧美一区二区精品久导航| 午夜精品国产更新| 91国内精品野花午夜精品 | 久久亚洲一区二区三区明星换脸 | 久久成人免费日本黄色| 欧美日韩国产另类不卡| 亚洲国产精品久久艾草纯爱| 波多野结衣一区二区三区| 久久精品视频一区二区| 蜜桃视频一区二区三区| 4hu四虎永久在线影院成人| 亚洲成人免费影院| 欧美午夜精品一区二区三区 | 国产精品久久久久久久久免费樱桃 | 91精品久久久久久蜜臀| 一区二区三区中文字幕| 91啦中文在线观看|