/usr/include/m17n-gui.h is in libm17n-dev 1.6.4-2ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 | /* m17n-gui.h -- header file for the GUI API of the m17n library.
Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012
National Institute of Advanced Industrial Science and Technology (AIST)
Registration Number H15PRO112
This file is part of the m17n library.
The m17n library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public License
as published by the Free Software Foundation; either version 2.1 of
the License, or (at your option) any later version.
The m17n library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with the m17n library; if not, write to the Free
Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
02111-1307, USA. */
#ifndef _M17N_GUI_H_
#define _M17N_GUI_H_
#ifndef _M17N_FLT_H_
#include <m17n-flt.h>
#endif
#ifndef _M17N_H_
#include <m17n.h>
#endif
M17N_BEGIN_HEADER
#if !defined (FOR_DOXYGEN) || defined (DOXYGEN_INTERNAL_MODULE)
extern void m17n_init_win (void);
#undef M17N_INIT
#define M17N_INIT() m17n_init_win ()
extern void m17n_fini_win (void);
#undef M17N_FINI
#define M17N_FINI() m17n_fini_win ()
#endif
/***en @defgroup m17nGUI GUI API
@brief API provided by libm17n-gui.so */
/***ja @defgroup m17nGUI GUI API
@brief libm17n-gui.so ¤¬Ä󶡤¹¤ë API */
/*=*/
/*** @ingroup m17nGUI */
/***en @defgroup m17nFrame Frame */
/***ja @defgroup m17nFrame ¥Õ¥ì¡¼¥à */
/*=*/
/*** @ingroup m17nFrame */
/***en
@brief Type of frames.
The type #MFrame is for a @e frame object. Each frame holds
various information about the corresponding physical display/input
device.
The internal structure of the type #MFrame is concealed from an
application program, and its contents depend on the window system
in use. In the m17n-X library, it contains the information about
@e display and @e screen in the X Window System. */
/***ja
@brief ¥Õ¥ì¡¼¥à¤Î·¿Àë¸À.
#MFrame ¤Ï¡¢@e ¥Õ¥ì¡¼¥à ¥ª¥Ö¥¸¥§¥¯¥ÈÍѤη¿¤Ç¤¢¤ë¡£
¸Ä¡¹¤Î¥Õ¥ì¡¼¥à¤Ï¡¢¤½¤ì¤¬Âбþ¤¹¤ëʪÍýŪ¤Êɽ¼¨¡¿ÆþÎϥǥХ¤¥¹¤Î³Æ¼ï¾ðÊó¤òÊÝ»ý¤¹¤ë¡£
#MFrame ·¿¤ÎÆâÉô¹½Â¤¤Ï¡¢¥¢¥×¥ê¥±¡¼¥·¥ç¥ó¥×¥í¥°¥é¥à¤«¤é¤Ï¸«¤¨¤Ê¤¤¡£
¤Þ¤¿¤½¤ÎÆâÍƤϻÈÍѤ¹¤ë¥¦¥£¥ó¥É¥¦¥·¥¹¥Æ¥à¤Ë°Í¸¤¹¤ë¡£¤Þ¤¿ m17n-X
¥é¥¤¥Ö¥é¥ê¤Ë¤ª¤±¤ë¥Õ¥ì¡¼¥à¤Ï¡¢X ¥¦¥£¥ó¥É¥¦¤Î @e display ¤È @e screen
¤Ë´Ø¤¹¤ë¾ðÊó¤ò»ý¤Ä¡£ */
typedef struct MFrame MFrame;
/*=*/
extern MSymbol Mdevice;
extern MSymbol Mfont;
extern MSymbol Mfont_width;
extern MSymbol Mfont_ascent;
extern MSymbol Mfont_descent;
extern MFrame *mframe_default;
extern MSymbol Mdisplay;
extern MSymbol Mscreen;
extern MSymbol Mdrawable;
extern MSymbol Mwidget;
extern MSymbol Mdepth;
extern MSymbol Mcolormap;
extern MFrame *mframe (MPlist *plist);
extern void *mframe_get_prop (MFrame *frame, MSymbol key);
/* end of frame module */
/*=*/
/*** @ingroup m17nGUI */
/***en @defgroup m17nFont Font */
/***ja @defgroup m17nFont ¥Õ¥©¥ó¥È */
/*=*/
/*** @ingroup m17nFont */
/***en
@brief Type of fonts.
The type #MFont is the structure defining fonts. It contains
information about the following properties of a font: foundry,
family, weight, style, stretch, adstyle, registry, size, and
resolution.
This structure is used both for specifying a font in a fontset
and for storing information about available system fonts.
The internal structure is concealed from an application program. */
/***ja
@brief ¥Õ¥©¥ó¥È¤Î·¿Àë¸À.
#MFont ·¿¤Ï¥Õ¥©¥ó¥È»ØÄêÍѤι½Â¤ÂΤǤ¢¤ê¡¢¥Õ¥©¥ó¥È¤Î¥×¥í¥Ñ¥Æ¥£¤Ç¤¢¤ë
foundry, family, weight, style, stretch, adstyle, registry,
size, resolution ¤Ë´Ø¤¹¤ë¾ðÊó¤ò´Þ¤à¡£
¤³¤Î¹½Â¤ÂΤϥե©¥ó¥È¥»¥Ã¥ÈÆâ¤Î¥Õ¥©¥ó¥È¤ò»ØÄꤹ¤ëºÝ¤È¡¢»ÈÍѲÄǽ¤Ê¥·¥¹¥Æ¥à¥Õ¥©¥ó¥È¤Î¾ðÊó¤ò³ÊǼ¤¹¤ëºÝ¤ÎξÊý¤ËÍѤ¤¤é¤ì¤ë¡£
ÆâÉô¹½Â¤¤Ï¥¢¥×¥ê¥±¡¼¥·¥ç¥ó¥×¥í¥°¥é¥à¤«¤é¤Ï¸«¤¨¤Ê¤¤¡£ */
/***
@seealso
mfont (), mfont_from_name (), mfont_find (). */
typedef struct MFont MFont;
/*=*/
extern MSymbol Mx, Mfreetype, Mxft;
extern MPlist *mfont_freetype_path;
extern MFont *mfont ();
extern MFont *mfont_copy (MFont *font);
extern MFont *mfont_parse_name (const char *name, MSymbol format);
extern char *mfont_unparse_name (MFont *font, MSymbol format);
/* These two are obsolete (from 1.1.0). */
extern char *mfont_name (MFont *font);
extern MFont *mfont_from_name (const char *name);
extern MSymbol Mfoundry;
extern MSymbol Mfamily;
extern MSymbol Mweight;
extern MSymbol Mstyle;
extern MSymbol Mstretch;
extern MSymbol Madstyle;
extern MSymbol Mspacing;
extern MSymbol Mregistry;
extern MSymbol Msize;
extern MSymbol Mresolution;
extern MSymbol Mmax_advance;
extern MSymbol Motf;
extern MSymbol Mfontfile;
extern MSymbol Mfontconfig;
extern void *mfont_get_prop (MFont *font, MSymbol key);
extern int mfont_put_prop (MFont *font, MSymbol key, void *val);
extern int mfont_set_encoding (MFont *font,
MSymbol encoding_name, MSymbol repertory_name);
/*=*/
/***en
@brief Find a font.
The mfont_find () function returns a pointer to the available font
that matches best with the specification $SPEC in frame $FRAME.
$SCORE, if not NULL, must point to a place to store the score
value which indicates how well the found font matches $SPEC. The
smaller score means a better match.
$LIMITED_SIZE, if nonzero, forces the font selector to find a
font not greater than the #Msize property of $SPEC. */
/***ja
@brief ¥Õ¥©¥ó¥È¤òõ¤¹.
´Ø¿ô mfont_find () ¤Ï¡¢¥Õ¥ì¡¼¥à $FRAME ¾å¤Ç¥Õ¥©¥ó¥ÈÄêµÁ $SPEC
¤Ë¤â¤Ã¤È¤â¹çÃפ¹¤ë»ÈÍѲÄǽ¤Ê¥Õ¥©¥ó¥È¤Ø¤Î¥Ý¥¤¥ó¥¿¤òÊÖ¤¹¡£
$SCORE ¤Ï NULL ¤Ç¤¢¤ë¤«¡¢¸«¤Ä¤«¤Ã¤¿¥Õ¥©¥ó¥È¤¬ $SPEC
¤Ë¤É¤ì¤Û¤É¹ç¤Ã¤Æ¤¤¤ë¤«¤ò¼¨¤¹¥¹¥³¥¢¤òÊݸ¤¹¤ë¾ì½ê¤Ø¤Î¥Ý¥¤¥ó¥¿¤Ç¤¢¤ë¡£
¥¹¥³¥¢¤¬¾®¤µ¤¤¤Û¤ÉÎɤ¯¹ç¤Ã¤Æ¤¤¤ë¤³¤È¤ò°ÕÌ£¤¹¤ë¡£
$LIMITED_SIZE ¤¬ 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢$SPEC ¤Î¥×¥í¥Ñ¥Æ¥£ #Msize
¤è¤êÂ礤¯¤Ê¤¤¥Õ¥©¥ó¥È¤À¤±¤¬Ãµ¤µ¤ì¤ë¡£
*/
extern MFont *mfont_find (MFrame *frame, MFont *spec,
int *score, int limited_size);
extern MSymbol *mfont_selection_priority ();
extern int mfont_set_selection_priority (MSymbol *keys);
extern int mfont_resize_ratio (MFont *font);
extern MPlist *mfont_list (MFrame *frame, MFont *font, MSymbol language,
int maxnum);
extern MPlist *mfont_list_family_names (MFrame *frame);
typedef struct MFontset MFontset;
extern int mfont_check (MFrame *frame, MFontset *fontset,
MSymbol script, MSymbol language, MFont *font);
extern int mfont_match_p (MFont *font, MFont *spec);
extern MFont *mfont_open (MFrame *frame, MFont *font);
extern MFont *mfont_encapsulate (MFrame *frame, MSymbol data_type, void *data);
extern int mfont_close (MFont *font);
/* end of font module */
/*=*/
/*** @ingroup m17nGUI */
/***en @defgroup m17nFontset Fontset */
/***ja @defgroup m17nFontset ¥Õ¥©¥ó¥È¥»¥Ã¥È */
/*=*/
/*** @addtogroup m17nFontset
@{ */
extern MFontset *mfontset (char *name);
extern MSymbol mfontset_name (MFontset *fontset);
extern MFontset *mfontset_copy (MFontset *fontset, char *name);
extern int mfontset_modify_entry (MFontset *fontset,
MSymbol language, MSymbol script,
MSymbol charset,
MFont *spec, MSymbol layouter_name,
int how);
extern MPlist *mfontset_lookup (MFontset *fontset, MSymbol script,
MSymbol language, MSymbol charset);
/*** @} */
/* end of fontset module */
/*=*/
/*** @ingroup m17nGUI */
/***en @defgroup m17nFace Face */
/***ja @defgroup m17nFace ¥Õ¥§¡¼¥¹ */
/*=*/
/*** @ingroup m17nFace */
/***en
@brief Type of faces.
The type #MFace is the structure of face objects. The internal
structure is concealed from an application program. */
/***ja
@brief ¥Õ¥§¡¼¥¹¤Î·¿Àë¸À.
#MFace ·¿¤Ï¥Õ¥§¡¼¥¹¥ª¥Ö¥¸¥§¥¯¥È¤Î¤¿¤á¤Î¹½Â¤ÂΤǤ¢¤ë¡£
ÆâÉô¹½Â¤¤Ï¥¢¥×¥ê¥±¡¼¥·¥ç¥ó¥×¥í¥°¥é¥à¤«¤é¤Ï¸«¤¨¤Ê¤¤¡£ */
typedef struct MFace MFace;
/*=*/
extern MSymbol Mforeground;
extern MSymbol Mbackground;
extern MSymbol Mvideomode;
extern MSymbol Mnormal;
extern MSymbol Mreverse;
extern MSymbol Mhline;
extern MSymbol Mbox;
extern MSymbol Mfontset;
extern MSymbol Mratio;
extern MSymbol Mhook_func;
extern MSymbol Mhook_arg;
/* Predefined faces. */
extern MFace *mface_normal_video;
extern MFace *mface_reverse_video;
extern MFace *mface_underline;
extern MFace *mface_medium;
extern MFace *mface_bold;
extern MFace *mface_italic;
extern MFace *mface_bold_italic;
extern MFace *mface_xx_small;
extern MFace *mface_x_small;
extern MFace *mface_small;
extern MFace *mface_normalsize;
extern MFace *mface_large;
extern MFace *mface_x_large;
extern MFace *mface_xx_large;
extern MFace *mface_black;
extern MFace *mface_white;
extern MFace *mface_red;
extern MFace *mface_green;
extern MFace *mface_blue;
extern MFace *mface_cyan;
extern MFace *mface_yellow;
extern MFace *mface_magenta;
/* etc */
extern MSymbol Mface;
extern MFace *mface ();
extern int mface_equal (MFace *face1, MFace *face2);
extern MFace *mface_copy (MFace *face);
extern MFace *mface_merge (MFace *dst, MFace *src);
extern MFace *mface_from_font (MFont *font);
/*=*/
/*** @ingroup m17nFace */
/***en
@brief Type of horizontal line spec of face.
The type #MFaceHLineProp is to specify the detail of #Mhline
property of a face. The value of the property must be a pointer
to an object of this type. */
/***ja
@brief ¥Õ¥§¡¼¥¹¤Î¿åÊ¿Àþ»ØÄêÍÑ·¿Àë¸À.
#MFaceHLineProp ¤Ï¥Õ¥§¡¼¥¹¤Î #Mhline
¥×¥í¥Ñ¥Æ¥£¤Î¾ÜºÙ¤ò»ØÄꤹ¤ë·¿¤Ç¤¢¤ë¡£¤³¤Î¥×¥í¥Ñ¥Æ¥£¤ÎÃͤϤ³¤Î·¿¤Î¥ª¥Ö¥¸¥§¥¯¥È¤Ç¤Ê¤¯¤Æ¤Ï¤Ê¤é¤Ê¤¤¡£
*/
typedef struct
{
/***en Type of the horizontal line. */
/***ja ¿åÊ¿Àþ¤Î¥¿¥¤¥×. */
enum MFaceHLineType
{
MFACE_HLINE_BOTTOM,
MFACE_HLINE_UNDER,
MFACE_HLINE_STRIKE_THROUGH,
MFACE_HLINE_OVER,
MFACE_HLINE_TOP
} type;
/***en Width of the line in pixels. */
/***ja ÀþÉý¡Ê¥Ô¥¯¥»¥ëñ°Ì¡Ë. */
unsigned width;
/***en Color of the line. If the value is Mnil, foreground color of
a merged face is used. */
/***ja Àþ¤Î¿§. Mnil ¤Ê¤é¤Ð¡¢Åý¹ç¤·¤¿¥Õ¥§¡¼¥¹¤ÎÁ°·Ê¿§¤¬»È¤ï¤ì¤ë¡£ */
MSymbol color;
} MFaceHLineProp;
/*=*/
/*** @ingroup m17nFace */
/***en
@brief Type of box spec of face.
The type #MFaceBoxProp is to specify the detail of #Mbox property
of a face. The value of the property must be a pointer to an
object of this type. */
/***ja
@brief ¥Õ¥§¡¼¥¹¤Î°Ï¤ßÏÈ»ØÄêÍÑ·¿Àë¸À.
#MFaceBoxProp ¤Ï¥Õ¥§¡¼¥¹¤Î #Mbox ¥×¥í¥Ñ¥Æ¥£¤Î¾ÜºÙ¤ò»ØÄꤹ¤ë·¿¤Ç¤¢¤ë¡£
¤³¤Î¥×¥í¥Ñ¥Æ¥£¤ÎÃͤϤ³¤Î·¿¤Î¥ª¥Ö¥¸¥§¥¯¥È¤Ø¤Î¥Ý¥¤¥ó¥¿¤Ç¤Ê¤¯¤Æ¤Ï¤Ê¤é¤Ê¤¤¡£
*/
typedef struct
{
/***en Width of the box line in pixels. */
/***ja ÀþÉý¡Ê¥Ô¥¯¥»¥ëñ°Ì¡Ë. */
unsigned width;
/* @{ */
/*** Colors of borders. */
MSymbol color_top;
MSymbol color_bottom;
MSymbol color_left;
MSymbol color_right;
/* @} */
/* @{ */
/*** Margins */
unsigned inner_hmargin;
unsigned inner_vmargin;
unsigned outer_hmargin;
unsigned outer_vmargin;
/* @} */
} MFaceBoxProp;
/*=*/
/*** @ingroup m17nFace */
/***en
@brief Type of hook function of face.
#MFaceHookFunc is a type of a hook function of a face. */
/***ja
@brief ¥Õ¥§¡¼¥¹¤Î¥Õ¥Ã¥¯´Ø¿ô¤Î·¿Àë¸À.
#MFaceHookFunc ¤Ï¥Õ¥§¡¼¥¹¤Î¥Õ¥Ã¥¯´Ø¿ô¤Î·¿¤Ç¤¢¤ë¡£*/
typedef void (*MFaceHookFunc) (MFace *face, void *arg, void *info);
/*=*/
extern void *mface_get_prop (MFace *face, MSymbol key);
extern int mface_put_prop (MFace *face, MSymbol key, void *val);
extern MFaceHookFunc mface_get_hook (MFace *face);
extern int mface_put_hook (MFace *face, MFaceHookFunc func);
extern void mface_update (MFrame *frame, MFace *face);
/* end of face module */
/*=*/
/*** @ingroup m17nGUI */
/***en @defgroup m17nDraw Drawing */
/***ja @defgroup m17nDraw ɽ¼¨ */
/*=*/
/*** @ingroup m17nDraw */
/***en
@brief Window system dependent type for a window.
The type #MDrawWindow is for a window; a rectangular area that
works in several ways like a miniature screen.
What it actually points depends on a window system. A program
that uses the m17n-X library must coerce the type @c Drawable to
this type. */
/***ja
@brief ¥¦¥£¥ó¥É¥¦¥·¥¹¥Æ¥à¤Ë°Í¸¤¹¤ë¡¢¥¦¥£¥ó¥É¥¦¤Î·¿Àë¸À.
#MDrawWindow ¤Ï¥¦¥£¥ó¥É¥¦¡¢¤¹¤Ê¤ï¤Á´ö¤Ä¤«¤ÎÅÀ¤Ç¥¹¥¯¥ê¡¼¥ó¤Î¥ß¥Ë¥Á¥å¥¢¤È¤·¤ÆƯ¤¯¶ë·ÁÎΰèÍѤη¿¤Ç¤¢¤ë¡£
¼ÂºÝ¤Ë²¿¤ò»Ø¤¹¤«¤Ï¥¦¥£¥ó¥É¥¦¥·¥¹¥Æ¥à¤Ë°Í¸¤¹¤ë¡£ m17n X
¥é¥¤¥Ö¥é¥ê¤òÍøÍѤ¹¤ë¥×¥í¥°¥é¥à¤Ï @c Drawable ·¿¤ò¤³¤Î·¿¤ËÊÑ´¹¤·¤Ê¤¯¤Æ¤Ï¤Ê¤é¤Ê¤¤¡£ */
typedef void *MDrawWindow;
/*=*/
/*** @ingroup m17nDraw */
/***en
@brief Window system dependent type for a region.
The type #MDrawRegion is for a region; an arbitrary set of pixels
on the screen (typically a rectangular area).
What it actually points depends on a window system. A program
that uses the m17n-X library must coerce the type @c Region to
this type. */
/***ja
@brief ¥¦¥£¥ó¥É¥¦¥·¥¹¥Æ¥à¤Ë°Í¸¤¹¤ë¡¢Îΰè¤Î·¿Àë¸À.
#MDrawRegion ¤ÏÎΰ衢¤¹¤Ê¤ï¤Á¥¹¥¯¥ê¡¼¥ó¾å¤ÎǤ°Õ¤Î¥Ô¥¯¥»¥ë¤Î½¸¹ç¡Êŵ·¿Åª¤Ë¤Ï¶ë·ÁÎΰè¡ËÍѤη¿¤Ç¤¢¤ë¡£
¼ÂºÝ¤Ë²¿¤ò»Ø¤¹¤«¤Ï¥¦¥£¥ó¥É¥¦¥·¥¹¥Æ¥à¤Ë°Í¸¤¹¤ë¡£ m17n X
¥é¥¤¥Ö¥é¥ê¤òÍøÍѤ¹¤ë¥×¥í¥°¥é¥à¤Ï @c Region ·¿¤ò¤³¤Î·¿¤ËÊÑ´¹¤·¤Ê¤¯¤Æ¤Ï¤Ê¤é¤Ê¤¤¡£ */
typedef void *MDrawRegion;
/*=*/
/*** @ingroup m17nDraw */
/***en
@brief Type of a text drawing control.
The type #MDrawControl is the structure that controls how to draw
an M-text. */
/***ja
@brief ¥Æ¥¥¹¥Èɽ¼¨À©¸æ¤Î·¿Àë¸À.
#MDrawControl ·¿¤Ï¡¢M-text ¤ò¤É¤¦É½¼¨¤¹¤ë¤«¤òÀ©¸æ¤¹¤ë¹½Â¤ÂΤǤ¢¤ë¡£
*/
typedef struct
{
/***en If nonzero, draw an M-text as image, i.e. with background
filled with background colors of faces put on the M-text.
Otherwise, the background is not changed. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢ M-text ¤ò²èÁü¤È¤·¤Æ¡¢¤¹¤Ê¤ï¤ÁÇطʤò M-text
¤Î¥Õ¥§¡¼¥¹¤Ç»ØÄꤵ¤ì¤Æ¤¤¤ëÇØ·Ê¿§¤ÇËä¤á¤Æɽ¼¨¤¹¤ë¡£¤½¤¦¤Ç¤Ê¤±¤ì¤ÐÇطʤÏÊѤï¤é¤Ê¤¤¡£ */
unsigned as_image : 1;
/***en If nonzero and the first glyph of each line has negative
lbearing, shift glyphs horizontally to right so that no pixel is
drawn to the left of the specified position. */
/***ja 0 ¤Ç¤Ê¤¯¡¢³Æ¹Ô¤ÎºÇ½é¤Î¥°¥ê¥Õ¤Î lbearing
¤¬Éé¤Ê¤é¤Ð¡¢¥°¥ê¥Õ¤ò¿åÊ¿¤Ë±¦¤Ë¤º¤é¤·¤Æ¡¢»ØÄꤷ¤¿°ÌÃÖ¤è¤êº¸¤Ë¥Ô¥¯¥»¥ë¤¬ÉÁ¤«¤ì¤Ê¤¤¤è¤¦¤Ë¤¹¤ë¡£ */
unsigned align_head : 1;
/***en If nonzero, draw an M-text two-dimensionally, i.e., newlines
in M-text breaks lines and the following characters are drawn in
the next line. If \<format\> is non-NULL, and the function
returns nonzero line width, a line longer than that width is
also broken. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢M-text ¤ò£²¼¡¸µÅª¤Ë¡¢¤¹¤Ê¤ï¤Á M-text Ãæ¤Î
newline ¤Ç²þ¹Ô¤·¡¢Â³¤¯Ê¸»ú¤Ï¼¡¤Î¹Ô¤Ëɽ¼¨¤¹¤ë¡£¤â¤· \<format\> ¤¬
NULL ¤Ç¤Ê¤¯¡¢¤½¤Î´Ø¿ô¤¬ 0 ¤Ç¤Ê¤¤¹ÔÉý¤òÊÖ¤»¤Ð¡¢¤½¤ÎÉý¤è¤êŤ¤¹Ô¤â²þ¹Ô¤µ¤ì¤ë¡£ */
unsigned two_dimensional : 1;
/***en If nonzero, draw an M-text to the right of a specified
position. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢M-text ¤ò»ØÄꤷ¤¿°ÌÃ֤ᦤËɽ¼¨¤¹¤ë¡£ */
unsigned orientation_reversed : 1;
/***en If nonzero, reorder glyphs correctly for bidi text. */
/***ja 0 ¤Ê¤±¤ì¤Ð¡¢bidi ¥Æ¥¥¹¥ÈÍѤ˥°¥ê¥Õ¤òÀµ¤·¤¯À°Î󤹤롣 */
unsigned enable_bidi : 1;
/***en If nonzero, don't draw characters whose general category (in
Unicode) is Cf (Other, format). */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢¥æ¥Ë¥³¡¼¥É¤ËÃÖ¤±¤ë°ìÈÌ¥«¥Æ¥´¥ê¤¬ Cf (Other,
format) ¤Ç¤¢¤ëʸ»ú¤òɽ¼¨¤·¤Ê¤¤¡£ */
unsigned ignore_formatting_char : 1;
/***en If nonzero, draw glyphs suitable for a terminal. Not yet
implemented. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢Ã¼ËöÍѤΥ°¥ê¥Õ¤òɽ¼¨¤¹¤ë¡£Ì¤¼ÂÁõ¡£ */
unsigned fixed_width : 1;
/***en If nonzero, draw glyphs with anti-aliasing if a backend font
driver supports it. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢¥¢¥ó¥Á¥¨¡¼¥ê¥¢¥¹¤Ç¥°¥ê¥Õ¤òɽ¼¨¤¹¤ë¡£
¡Ê¥Ð¥Ã¥¯¥¨¥ó¥É¤Î¥Õ¥©¥ó¥È¥É¥é¥¤¥Ð¤¬¥¢¥ó¥Á¥¨¡¼¥ê¥¢¥¹µ¡Ç½¤ò»ý¤Ä¾ì¹ç¤Î¤ß¡£¡Ë */
unsigned anti_alias : 1;
/***en If nonzero, disable the adjustment of glyph positions to
avoid horizontal overlapping at font boundary. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢¥Õ¥©¥ó¥È¶³¦¤Ç¤Î¿åÊ¿Êý¸þ¤Î¥°¥ê¥Õ¤Î½Å¤Ê¤ê¤òÈò¤±¤ë¤¿¤á¤Î¥°¥ê¥Õ°ÌÃÖ¤ÎÄ´À°¤ò̵¸ú¤Ë¤¹¤ë¡£ */
unsigned disable_overlapping_adjustment : 1;
/***en If nonzero, the values are minimum line ascent pixels. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢ÃͤϹԤΠascent ¤ÎºÇ¾®Ãͤò¼¨¤¹¡£ */
unsigned int min_line_ascent;
/***en If nonzero, the values are minimum line descent pixels. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢ÃͤϹԤΠdescent ¤ÎºÇ¾®Ãͤò¼¨¤¹¡£ */
unsigned int min_line_descent;
/***en If nonzero, the values are maximum line ascent pixels. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢ÃͤϹԤΠascent ¤ÎºÇÂçÃͤò¼¨¤¹¡£ */
unsigned int max_line_ascent;
/***en If nonzero, the values are maximum line descent pixels. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢ÃͤϹԤΠdescent ¤ÎºÇÂçÃͤò¼¨¤¹¡£ */
unsigned int max_line_descent;
/***en If nonzero, the value specifies how many pixels each line can
occupy on the display. The value zero means that there is no
limit. It is ignored if \<format\> is non-NULL. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢ÃͤϤ³¤Î¥Ç¥£¥¹¥×¥ì¥¤¾å¤Ç³Æ¹Ô¤¬Àê¤á¤ë¤³¤È¤Î¤Ç¤¤ë¥Ô¥¯¥»¥ë¿ô¤ò¼¨¤¹¡£
0 ¤Ï¸ÂÄꤵ¤ì¤Ê¤¤¤³¤È¤ò°ÕÌ£¤¹¤ë¡£\<format\> ¤¬ NULL ¤Ç¤Ê¤±¤ì¤Ð̵»ë¤µ¤ì¤ë¡£ */
unsigned int max_line_width;
/***en If nonzero, the value specifies the distance between tab
stops in columns (the width of one column is the width of a
space in the default font of the frame). The value zero means
8. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢Ãͤϥ¿¥Ö¥¹¥È¥Ã¥×´Ö¤Îµ÷Î¥¤ò¥³¥é¥àñ°Ì
¡Ê¥³¥é¥à¤Ï¥Õ¥ì¡¼¥à¤Î¥Ç¥Õ¥©¥ë¥È¥Õ¥©¥ó¥È¤Ë¤ª¤±¤ë¶õÇòʸ»ú¤ÎÉý¤Ç¤¢¤ë¡Ë¤Ç¼¨¤¹¡£
0 ¤Ï 8 ¤ò°ÕÌ£¤¹¤ë¡£ */
unsigned int tab_width;
/***en If non-NULL, the value is a function that calculates the
indentation and width limit of each line based on the line
number LINE and the coordinate Y. The function store the
indentation and width limit at the place pointed by INDENT and
WIDTH respectively.
The indentation specifies how many pixels the first glyph of
each line is shifted to the right (if the member
\<orientation_reversed\> is zero) or to the left (otherwise). If
the value is negative, each line is shifted to the reverse
direction.
The width limit specifies how many pixels each line can occupy
on the display. The value 0 means that there is no limit.
LINE and Y are reset to 0 when a line is broken by a newline
character, and incremented each time when a long line is broken
because of the width limit.
This has an effect only when \<two_dimensional\> is nonzero. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢Ãͤϴؿô¤Ç¤¢¤ê¡¢¤½¤Î´Ø¿ô¤Ï¹ÔÈÖ¹æ LINE ¤ÈºÂɸ Y
¤Ë´ð¤Å¤¤¤Æ³Æ¹Ô¤Î¥¤¥ó¥Ç¥ó¥È¤ÈºÇÂçÉý¤ò·×»»¤·¡¢¤½¤ì¤¾¤ì¤òINDENT ¤È
WIDTH ¤Ç»Ø¤µ¤ì¤ë¾ì½ê¤ËÊݸ¤¹¤ë¡£
¥¤¥ó¥Ç¥ó¥È¤Ï¡¢³Æ¹Ô¤ÎºÇ½é¤Î¥°¥ê¥Õ¤ò±¦¡Ê¥á¥ó¥Ð
\<orientation_reversed\> ¤¬ 0
¤Î»þ¡Ë¤¢¤ë¤¤¤Ïº¸¡Ê¤½¤ì°Ê³°¤Î»þ¡Ë¤Ë²¿¥Ô¥¯¥»¥ë¤º¤é¤¹¤«¤ò»ØÄꤹ¤ë¡£Ãͤ¬Éé¤Ê¤é¤ÐµÕÊý¸þ¤Ë¤º¤é¤¹¡£
ºÇÂçÉý¤Ï¡¢³Æ¹Ô¤¬¥Ç¥£¥¹¥×¥ì¥¤¾å¤ÇÀê¤á¤ë¤³¤È¤Î¤Ç¤¤ë¥Ô¥¯¥»¥ë¿ô¤ÎºÇÂçÃͤǤ¢¤ë¡£Ãͤ¬
0 ¤Î¾ì¹ç¤ÏÀ©¸Â¤ò¼õ¤±¤Ê¤¤¤³¤È¤ò°ÕÌ£¤¹¤ë¡£
LINE ¤È Y ¤Ï²þ¹Ôʸ»ú¤Ë¤è¤Ã¤Æ¹Ô¤¬²þ¤Þ¤Ã¤¿ºÝ¤Ë¤Ï 0
¤Ë¥ê¥»¥Ã¥È¤µ¤ì¡¢Ä¹¤¤¹Ô¤¬ºÇÂçÉý¤ÎÀ©¸Â¤Ë¤è¤Ã¤Æ²þ¹Ô¤µ¤ì¤ë¤¿¤Ó¤Ë 1 Áý¤ä¤µ¤ì¤ë¡£
¤³¤ì¤Ï \<two_dimensional\> ¤¬ 0 ¤Ç¤Ê¤¤¾ì¹ç¤Ë¤Î¤ß͸ú¤Ç¤¢¤ë¡£ */
void (*format) (int line, int y, int *indent, int *width);
/***en If non-NULL, the value is a function that calculates a line
breaking position when a line is too long to fit within the
width limit. POS is the position of the character next to the
last one that fits within the limit. FROM is the position of the
first character of the line, and TO is the position of the last
character displayed on the line if there were not width limit.
LINE and Y are the same as the arguments to \<format\>.
The function must return a character position to break the
line.
The function should not modify MT.
The mdraw_default_line_break () function is useful for such a
script that uses SPACE as a word separator. */
/***ja NULL ¤Ç¤Ê¤±¤ì¤Ð¡¢ÃͤϹԤ¬ºÇÂçÉýÃæ¤Ë¼ý¤Þ¤é¤Ê¤¤¾ì¹ç¤Ë¹Ô¤ò²þ¤á¤ë°ÌÃÖ¤ò·×»»¤¹¤ë´Ø¿ô¤Ç¤¢¤ë¡£
POS ¤ÏºÇÂçÉý¤Ë¼ý¤Þ¤ëºÇ¸å¤Îʸ»ú¤Î¼¡¤Îʸ»ú¤Î°ÌÃ֤Ǥ¢¤ë¡£FROM
¤Ï¹Ô¤ÎºÇ½é¤Îʸ»ú¤Î°ÌÃÖ¡¢TO
¤ÏºÇÂçÉý¤¬»ØÄꤵ¤ì¤Æ¤¤¤Ê¤±¤ì¤Ð¤½¤Î¹Ô¤Ëɽ¼¨¤µ¤ì¤ëºÇ¸å¤Îʸ»ú¤Î°ÌÃ֤Ǥ¢¤ë¡£LINE
¤È Y ¤Ï \<format\> ¤Î°ú¿ô¤ÈƱÍͤǤ¢¤ë¡£
¤³¤Î´Ø¿ô¤Ï¹Ô¤ò²þ¤á¤ëʸ»ú°ÌÃÖ¤òÊÖ¤µ¤Ê¤¯¤Æ¤Ï¤Ê¤é¤Ê¤¤¡£¤Þ¤¿ MT ¤òÊѹ¹¤·¤Æ¤Ï¤Ê¤é¤Ê¤¤¡£
´Ø¿ô mdraw_default_line_break ()
¤Ï¡¢¶õÇò¤ò¸ì¤Î¶èÀÚ¤ê¤È¤·¤ÆÍѤ¤¤ë¥¹¥¯¥ê¥×¥ÈÍѤȤ·¤ÆÍÍѤǤ¢¤ë¡£ */
int (*line_break) (MText *mt, int pos, int from, int to, int line, int y);
/***en If nonzero, show the cursor according to \<cursor_width\>. */
/***ja ¥¼¥í¤Ç¤Ê¤±¤ì¤Ð \<cursor_width\> ¤Ë¤·¤¿¤¬¤Ã¤Æ¥«¡¼¥½¥ë¤òɽ¼¨¤¹¤ë¡£ */
int with_cursor;
/***en Specifies the character position to display a cursor. If it
is greater than the maximum character position, the cursor is
displayed next to the last character of an M-text. If the value
is negative, even if \<cursor_width\> is nonzero, cursor is not
displayed. */
/***ja ¥«¡¼¥½¥ë¤òɽ¼¨¤¹¤ëʸ»ú°ÌÃÖ¤ò¼¨¤¹¡£ºÇÂç¤Îʸ»ú°ÌÃÖ¤è¤êÂ礤±¤ì¤Ð¡¢¥«¡¼¥½¥ë¤Ï
M-text ¤ÎºÇ¸å¤Îʸ»ú¤ÎÎÙ¤Ëɽ¼¨¤µ¤ì¤ë¡£Éé¤Ê¤é¤Ð¡¢
\<cursor_width\> ¤¬ 0 ¤Ç¤Ê¤¯¤Æ¤â¥«¡¼¥½¥ë¤Ïɽ¼¨¤µ¤ì¤Ê¤¤¡£
*/
int cursor_pos;
/***en If nonzero, display a cursor at the character position
\<cursor_pos\>. If the value is positive, it is the pixel width
of the cursor. If the value is negative, the cursor width is
the same as the underlining glyph(s). */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢\<cursor_pos\> ¤Ë¥«¡¼¥½¥ë¤òɽ¼¨¤¹¤ë¡£
Ãͤ¬Àµ¤Ê¤é¤Ð¡¢¥«¡¼¥½¥ë¤ÎÉý¤Ï¤½¤ÎÃÍ¡Ê¥Ô¥¯¥»¥ëñ°Ì¡Ë¤Ç¤¢¤ë¡£
Éé¤Ê¤é¤Ð¡¢¥«¡¼¥½¥ë¤Î¤¢¤ë¥°¥ê¥Õ¤ÈƱ¤¸Éý¤Ç¤¢¤ë¡£ */
int cursor_width;
/***en If nonzero and \<cursor_width\> is also nonzero, display double
bar cursors; at the character position \<cursor_pos\> and at the
logically previous character. Both cursors have one pixel width
with horizontal fringes at upper or lower positions. */
/***ja If 0 ¤Ç¤Ê¤¯¡¢¤«¤Ä \<cursor_width\> ¤â 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢¥Ð¡¼¥«¡¼¥½¥ë¤òʸ»ú°ÌÃÖ
\<cursor_pos\> ¤ÈÏÀÍýŪ¤Ë¤½¤ì¤ÎÁ°¤Ë¤¢¤ëʸ»ú¤Î£²¥ö½ê¤Ëɽ¼¨¤¹¤ë¡£
ÁÐÊý¤È¤â£±¥Ô¥¯¥»¥ëÉý¤Ç¡¢¾å¤«²¼¤Ë¿åÊ¿¤Î¾þ¤ê¤¬¤Ä¤¯¡£*/
int cursor_bidi;
/***en If nonzero, on drawing partial text, pixels of surrounding
texts that intrude into the drawing area are also drawn. For
instance, some CVC sequence of Thai text (C is consonant, V is
upper vowel) is drawn so that V is placed over the middle of two
Cs. If this CVC sequence is already drawn and only the last C
is drawn again (for instance by updating cursor position), the
right half of V is erased if this member is zero. By setting
this member to nonzero, even with such a drawing, we can keep
this CVC sequence correctly displayed. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢¥Æ¥¥¹¥È¤Î°ìÉôʬ¤òɽ¼¨¤¹¤ëºÝ¤Ë¡¢Á°¸å¤Î¥Æ¥¥¹¥È¤Î¤¦¤Á¤½¤Îɽ¼¨Îΰè¤Ë¿¯Æþ¤¹¤ëÉôʬ¤âɽ¼¨¤¹¤ë¡£
¤¿¤È¤¨¤Ð¡¢¥¿¥¤¸ì¥Æ¥¥¹¥È »Ò²»-Êì²»-»Ò²»
¤È¤¤¤¦¥·¡¼¥¯¥¨¥ó¥¹¤Î¤¤¤¯¤Ä¤«¤Ï¡¢Êì²»¤¬Æó¤Ä¤Î»Ò²»¤Î´Ö¤Ë¾å¤Ë¤Î¤ë¤è¤¦¤ËÉÁ¤«¤ì¤ë¡£
¤³¤Î¤è¤¦¤Ê¥·¡¼¥¯¥¨¥ó¥¹¤¬¤¹¤Ç¤ËÉÁ¤«¤ì¤Æ¤ª¤ê¡¢ºÇ¸å¤Î»Ò²»¤À¤±¤òÉÁ¤Ä¾¤¹¾ì¹ç
¡Ê¤¿¤È¤¨¤Ð¡¢¥«¡¼¥½¥ë°ÌÃÖ¤ò¹¹¿·¤¹¤ëºÝ¤Ê¤É¡Ë¤³¤Î¥á¥ó¥Ð¤¬ 0
¤Ç¤¢¤ì¤Ð¡¢Êì²»¤Î±¦È¾Ê¬¤¬¾Ã¤µ¤ì¤Æ¤·¤Þ¤¦¡£¤³¤ì¤ò 0 °Ê³°¤Ë¤¹¤ë¤³¤È¤Ë¤è¤Ã¤Æ¡¢¤½¤Î¤è¤¦¤ÊºÝ¤Ë¤â
»Ò²»-Êì²»-»Ò²» ¤Î¥·¡¼¥¯¥¨¥ó¥¹¤òÀµ¤·¤¯É½¼¨¤·Â³¤±¤ë¤³¤È¤¬¤Ç¤¤ë¡£ */
int partial_update;
/***en If nonzero, don't cache the result of any drawing information
of an M-text. */
/***ja 0 ¤Ç¤Ê¤±¤ì¤Ð¡¢M-text ¤Îɽ¼¨¤Ë´Ø¤¹¤ë¾ðÊó¤ò¥¥ã¥Ã¥·¥å¤·¤Ê¤¤¡£
*/
int disable_caching;
/***en If non-NULL, limit the drawing effect to the specified region. */
/***ja NULL ¤Ç¤Ê¤±¤ì¤Ðɽ¼¨¥¨¥ê¥¢¤ò»ØÄꤵ¤ì¤¿Îΰè¤Ë¸ÂÄꤹ¤ë¡£ */
MDrawRegion clip_region;
} MDrawControl;
extern int mdraw_line_break_option;
/*=*/
/*** @ingroup m17nDraw */
/***en
@brief Type of metric for glyphs and texts.
The type #MDrawMetric is for a metric of a glyph and a drawn text.
It is also used to represent a rectangle area of a graphic
device. */
/***ja
@brief ¥°¥ê¥Õ¤È¥Æ¥¥¹¥È¤ÎÀ£Ë¡¤Î·¿Àë¸À.
#MDrawMetric ¤Ï¥°¥ê¥Õ¤Èɽ¼¨¤µ¤ì¤¿¥Æ¥¥¹¥È¤ÎÀ£Ë¡ÍѤη¿¤Ç¤¢¤ë¡£
¤Þ¤¿¡¢É½¼¨¥Ç¥Ð¥¤¥¹¤Î¶ë·ÁÎΰè¤òɽ¤¹¤Î¤Ë¤âÍѤ¤¤é¤ì¤ë¡£ */
typedef struct {
/*** X coordinates of a glyph or a text. */
int x;
/*** Y coordinates of a glyph or a text. */
int y;
/*** Pixel width of a glyph or a text. */
unsigned int width;
/*** Pixel height of a glyph or a text. */
unsigned int height;
} MDrawMetric;
/*=*/
/*** @ingroup m17nDraw */
/***en
@brief Type of information about a glyph.
The type #MDrawGlyphInfo is the structure that contains
information about a glyph. It is used by mdraw_glyph_info (). */
/***ja
@brief ¥°¥ê¥Õ¤Ë´Ø¤¹¤ë¾ðÊó¤Î·¿Àë¸À.
#MDrawGlyphInfo ·¿¤Ï¥°¥ê¥Õ¤Ë´Ø¤¹¤ë¾ðÊó¤ò´Þ¤à¹½Â¤ÂΤǤ¢¤ë¡£
mdraw_glyph_info () ¤Ï¤³¤ì¤òÍѤ¤¤ë¡£ */
typedef struct
{
/***en Start position of character range corresponding to the glyph. */
/***ja ¥°¥ê¥Õ¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈϰϤγ«»Ï°ÌÃÖ. */
int from;
/***en End position of character range corresponding to the glyph. */
/***ja ¥°¥ê¥Õ¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈϰϤνªÎ»°ÌÃÖ. */
int to;
/***en Start position of character range corresponding to the line of the glyph. */
/***ja °ì¹Ô¤Î¥°¥ê¥Õ¤ÎÎó¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈϰϤγ«»Ï°ÌÃÖ. */
int line_from;
/***en End position of character range corresponding to the line of the glyph. */
/***ja °ì¹Ô¤Î¥°¥ê¥Õ¤ÎÎó¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈϰϤνªÎ»°ÌÃÖ. */
int line_to;
/***en X coordinates of the glyph. */
/***ja ¥°¥ê¥Õ¤Î X ºÂɸ. */
int x;
/***en Y coordinates of the glyph. */
/***ja ¥°¥ê¥Õ¤Î Y ºÂɸ. */
int y;
/***en Metric of the glyph. */
/***ja ¥°¥ê¥Õ¤ÎÀ£Ë¡. */
MDrawMetric metrics;
/***en Font used for the glyph. Set to NULL if no font is found for
the glyph. */
/***ja ¥°¥ê¥Õ¤Ë»È¤ï¤ì¤ë¥Õ¥©¥ó¥È¡£¸«¤Ä¤«¤é¤Ê¤±¤ì¤Ð NULL¡£ */
MFont *font;
/***en Character ranges corresponding to logically previous glyphs.
Note that we do not need the members prev_to because it must
be the same as the member \<from\>. */
/***ja ÏÀÍýŪ¤ÊÁ°¤Î¥°¥ê¥Õ¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈÏ°Ï¡£¥á¥ó¥Ð prev_to ¤Ï¡¢¥á
¥ó¥Ð from ¤ÈƱ¤¸¤Ç¤¢¤ë¤Ï¤º¤Ê¤Î¤ÇÉÔÍפǤ¢¤ë¡£ */
int prev_from;
/***en Character ranges corresponding to logically next glyphs.
Note that we do not need the members next_from because it must
be the same as the member \<to\> respectively. */
/***ja ÏÀÍýŪ¤Ê¸å¤Î¥°¥ê¥Õ¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈÏ°Ï¡£¥á¥ó¥Ð next_from ¤Ï
¥á¥ó¥Ð to ¤ÈƱ¤¸¤Ç¤¢¤ë¤Ï¤º¤Ê¤Î¤ÇÉÔÍפǤ¢¤ë¡£ */
int next_to;
/***en Start position of character ranges corresponding to visually
left glyphs. */
/***ja ɽ¼¨¾å¤Îº¸¤Î¥°¥ê¥Õ¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈϰϤγ«»Ï°ÌÃÖ¡£ */
int left_from;
/***en End position of character ranges corresponding to visually
left glyphs. */
/***ja ɽ¼¨¾å¤Îº¸¤Î¥°¥ê¥Õ¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈϰϤνªÎ»°ÌÃÖ¡£ */
int left_to;
/***en Start position of character ranges corresponding to visually
right glyphs. */
/***ja ɽ¼¨¾å¤Î±¦¤Î¥°¥ê¥Õ¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈϰϤγ«»Ï°ÌÃÖ¡£ */
int right_from;
/***en End position of character ranges corresponding to visually
left glyphs. */
/***ja ɽ¼¨¾å¤Î±¦¤Î¥°¥ê¥Õ¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈϰϤνªÎ»°ÌÃÖ¡£ */
int right_to;
/***en Logical width of the glyph. Nominal distance to the next
glyph. */
/***ja ¥°¥ê¥Õ¤ÎÏÀÍýŪÉý¡£¼¡¤Î¥°¥ê¥Õ¤È¤Î̾Ìܾå¤Îµ÷Î¥¡£ */
int logical_width;
} MDrawGlyphInfo;
/*=*/
/*** @ingroup m17nDraw */
/***en
@brief Type of information about a glyph metric and font.
The type #MDrawGlyph is the structure that contains information
about a glyph metric and font. It is used by the function
mdraw_glyph_list (). */
/***ja
@brief ¥°¥ê¥Õ¤ÎÀ£Ë¡¤È¥Õ¥©¥ó¥È¤Ë´Ø¤¹¤ë¾ðÊó¤Î·¿Àë¸À.
#MDrawGlyph ·¿¤Ï¥°¥ê¥Õ¤ÎÀ£Ë¡¤È¥Õ¥©¥ó¥È¤Ë´Ø¤¹¤ë¾ðÊó¤ò´Þ¤à¹½Â¤ÂΤǤ¢¤ë¡£
mdraw_glyph_list () ¤Ï¤³¤ì¤òÍѤ¤¤ë¡£ */
typedef struct
{
/* @{ */
/***en Character range corresponding to the glyph. */
/***ja ¥°¥ê¥Õ¤ËÂбþ¤¹¤ëʸ»ú¤ÎÈÏ°Ï. */
int from, to;
/* @} */
/***en Font glyph code of the glyph. */
/***ja ¥Õ¥©¥ó¥ÈÆâ¤Î¥°¥ê¥Õ¥³¡¼¥É¡£ */
int glyph_code;
/***en Logical width of the glyph. Nominal distance to the next
glyph. */
/***ja ¥°¥ê¥Õ¤ÎÏÀÍýŪÉý¡£¼¡¤Î¥°¥ê¥Õ¤È¤Î̾Ìܾå¤Îµ÷Î¥¡£ */
int x_advance;
/***en Logical height of the glyph. Nominal distance to the next
glyph. */
/***ja ¥°¥ê¥Õ¤ÎÏÀÍýŪ¹â¤µ¡£¼¡¤Î¥°¥ê¥Õ¤È¤Î̾Ìܾå¤Îµ÷Î¥¡£ */
int y_advance;
/***en X offset relative to the glyph position. */
/***ja ¥°¥ê¥Õ¤Î°ÌÃÖ¤ËÂФ¹¤ë X ¥ª¥Õ¥»¥Ã¥È. */
int x_off;
/***en Y offset relative to the glyph position. */
/***ja ¥°¥ê¥Õ¤Î°ÌÃÖ¤ËÂФ¹¤ë Y ¥ª¥Õ¥»¥Ã¥È. */
int y_off;
/***en Metric of the glyph (left-bearing). */
/***ja ¥°¥ê¥Õ¤ÎÀ£Ë¡ (left-bearing). */
int lbearing;
/***en Metric of the glyph (right-bearing). */
/***ja ¥°¥ê¥Õ¤ÎÀ£Ë¡ (right-bearing). */
int rbearing;
/***en Metric of the glyph (ascent). */
/***ja ¥°¥ê¥Õ¤ÎÀ£Ë¡ (ascent). */
int ascent;
/***en Metric of the glyph (descent). */
/***ja ¥°¥ê¥Õ¤ÎÀ£Ë¡ (descent). */
int descent;
/***en Font used for the glyph. Set to NULL if no font is found for
the glyph. */
/***ja ¥°¥ê¥Õ¤Ë»È¤ï¤ì¤ë¥Õ¥©¥ó¥È¡£¸«¤Ä¤«¤é¤Ê¤±¤ì¤Ð NULL¡£ */
MFont *font;
/***en Type of the font. One of Mx, Mfreetype, Mxft. */
/***ja ¥Õ¥©¥ó¥È¤Î¥¿¥¤¥×¡£Mx¡¢Mfreetype¡¢Mxft ¤Î¤¤¤º¤ì¤«¡£ */
MSymbol font_type;
/***en Pointer to the font structure. The actual type is
(XFontStruct *) if \<font_type\> member is Mx, FT_Face if
\<font_type\> member is Mfreetype, and (XftFont *) if \<font_type\>
member is Mxft. */
/***ja ¥Õ¥©¥ó¥È¤Î¹½Â¤ÂΤؤΥݥ¤¥ó¥¿¡£¼ÂºÝ¤Î·¿¤Ï \<font_type\> ¥á¥ó¥Ð¤¬
Mx ¤Ê¤é (XFontStruct *)¡¢ Mfreetype ¤Ê¤é FT_Face¡¢Mxft
¤Ê¤é (XftFont *)¡£ */
void *fontp;
} MDrawGlyph;
/*=*/
/***en
@brief Type of textitems.
The type #MDrawTextItem is for @e textitem objects.
Each textitem contains an M-text and some other information to
control the drawing of the M-text. */
/***ja
@brief textitem ¤Î·¿Àë¸À.
#MDrawTextItem ¤Ï @e ¥Æ¥¥¹¥È¥¢¥¤¥Æ¥à ¥ª¥Ö¥¸¥§¥¯¥ÈÍѤη¿¤Ç¤¢¤ë¡£
³Æ¥Æ¥¥¹¥È¥¢¥¤¥Æ¥à¤Ï¡¢ 1 ¸Ä¤Î M-text ¤È¡¢¤½¤Îɽ¼¨¤òÀ©¸æ¤¹¤ë¤¿¤á¤Î¾ðÊó¤ò´Þ¤ó¤Ç¤¤¤ë¡£
@latexonly \IPAlabel{MTextItem} @endlatexonly */
typedef struct
{
/***en M-text. */
/***ja M-text. */
MText *mt;
/***en Optional change in the position (in the unit of pixel) along
the X-axis before the M-text is drawn. */
/***ja M-text ɽ¼¨Á°¤Ë¹Ô¤Ê¤¦X¼´Êý¸þ¤Î°ÌÃÖÄ´À° (¥Ô¥¯¥»¥ëñ°Ì) */
int delta;
/***en Pointer to a face object. Each property of the face, if not
Mnil, overrides the same property of face(s) specified as a text
property in \<mt\>. */
/***ja ¥Õ¥§¡¼¥¹¥ª¥Ö¥¸¥§¥¯¥È¤Ø¤Î¥Ý¥¤¥ó¥¿¡£¥Õ¥§¡¼¥¹¤Î³Æ¥×¥í¥Ñ¥Æ¥£¤Ï
Mnil ¤Ç¤Ê¤±¤ì¤Ð \<mt\> ¤Ç»ØÄꤵ¤ì¤¿¥Õ¥§¡¼¥¹¤ÎƱ¤¸¥×¥í¥Ñ¥Æ¥£¤ËÍ¥À褹¤ë*/
MFace *face;
/***en Pointer to a draw control object. The M-text \<mt\> is drawn
by mdraw_text_with_control () with this control object. */
/***ja ɽ¼¨À©¸æ¥ª¥Ö¥¸¥§¥¯¥È¤Ø¤Î¥Ý¥¤¥ó¥¿¡£ mdraw_text_with_control ()
¤Ï¤³¤Î¥ª¥Ö¥¸¥§¥¯¥È¤òÍѤ¤¤Æ M-text \<mt\> ¤òɽ¼¨¤¹¤ë¡£ */
MDrawControl *control;
} MDrawTextItem;
/*=*/
extern int mdraw_text (MFrame *frame, MDrawWindow win, int x, int y,
MText *mt, int from, int to);
extern int mdraw_image_text (MFrame *frame, MDrawWindow win, int x, int y,
MText *mt, int from, int to);
extern int mdraw_text_with_control (MFrame *frame, MDrawWindow win,
int x, int y, MText *mt, int from, int to,
MDrawControl *control);
extern int mdraw_coordinates_position (MFrame *frame,
MText *mt, int from, int to,
int x, int y, MDrawControl *control);
extern int mdraw_text_extents (MFrame *frame,
MText *mt, int from, int to,
MDrawControl *control,
MDrawMetric *overall_ink_return,
MDrawMetric *overall_logical_return,
MDrawMetric *overall_line_return);
extern int mdraw_text_per_char_extents (MFrame *frame,
MText *mt, int from, int to,
MDrawControl *control,
MDrawMetric *ink_array_return,
MDrawMetric *logical_array_return,
int array_size,
int *num_chars_return,
MDrawMetric *overall_ink_return,
MDrawMetric *overall_logical_return);
extern int mdraw_glyph_info (MFrame *frame, MText *mt, int from, int pos,
MDrawControl *control, MDrawGlyphInfo *info);
extern int mdraw_glyph_list (MFrame *frame, MText *mt, int from, int to,
MDrawControl *control, MDrawGlyph *glyphs,
int array_size, int *num_glyphs_return);
extern void mdraw_text_items (MFrame *frame, MDrawWindow win, int x, int y,
MDrawTextItem *items, int nitems);
extern void mdraw_per_char_extents (MFrame *frame, MText *mt,
MDrawMetric *array_return,
MDrawMetric *overall_return);
extern int mdraw_default_line_break (MText *mt, int pos,
int from, int to, int line, int y);
extern void mdraw_clear_cache (MText *mt);
/* end of drawing module */
/*=*/
/*** @ingroup m17nGUI */
/***en @defgroup m17nInputMethodWin Input Method (GUI) */
/***ja @defgroup m17nInputMethodWin ÆþÎϥ᥽¥Ã¥É (GUI) */
/*=*/
extern MInputDriver minput_gui_driver;
/*=*/
/*** @ingroup m17nInputMethodWin */
/***en
@brief Type of the argument to the function minput_create_ic ().
The type #MInputGUIArgIC is for the argument $ARG of the function
minput_create_ic () to create an input context of an internal
input method. */
/***ja
@brief ´Ø¿ô minput_create_ic () ¤Î°ú¿ô¤Î·¿Àë¸À.
#MInputGUIArgIC ¤Ï¡¢´Ø¿ô minput_create_ic ()
¤¬ÆâÉôÆþÎϥ᥽¥Ã¥É¤ÎÆþÎÏ¥³¥ó¥Æ¥¯¥¹¥È¤òÀ¸À®¤¹¤ëºÝ¤Î¡¢°ú¿ô $ARG ÍѤη¿¤Ç¤¢¤ë¡£ */
typedef struct
{
/***en Frame of the client. */
/***ja ¥¯¥é¥¤¥¢¥ó¥È¤Î¥Õ¥ì¡¼¥à */
MFrame *frame;
/***en Window on which to display the preedit and status text. */
/***ja preedit ¥Æ¥¥¹¥È¤È status ¥Æ¥¥¹¥È¤òɽ¼¨¤¹¤ë¥¦¥£¥ó¥É¥¦ */
MDrawWindow client;
/***en Window that the input context has a focus on. */
/***ja ÆþÎÏ¥³¥ó¥Æ¥¯¥¹¥È¤¬¥Õ¥©¡¼¥«¥¹¤ò¤ª¤¤¤Æ¤¤¤ë¥¦¥£¥ó¥É¥¦ */
MDrawWindow focus;
} MInputGUIArgIC;
/*=*/
extern MSymbol minput_event_to_key (MFrame *frame, void *event);
/* end of input module */
/*=*/
/* end of window modules */
/*=*/
extern MFace *mdebug_dump_face (MFace *face, int indent);
extern MFont *mdebug_dump_font (MFont *font);
extern MFontset *mdebug_dump_fontset (MFontset *fontset, int indent);
M17N_END_HEADER
#endif /* _M17N_GUI_H_ */
/*
Local Variables:
coding: euc-japan
End:
*/
|