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

📄 _cfpf.h

📁 Windows CE 6.0 Word Application 源码
💻 H
字号:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft shared
// source or premium shared source license agreement under which you licensed
// this source code. If you did not accept the terms of the license agreement,
// you are not authorized to use this source code. For the terms of the license,
// please see the license agreement between you and Microsoft or, if applicable,
// see the SOURCE.RTF on your install media or the root of your tools installation.
// THE SOURCE CODE IS PROVIDED "AS IS", WITH NO WARRANTIES.
//
/*
 *	@doc 	INTERNAL
 *
 *	@module _CFPF.H	-- RichEdit CCharFormat and CParaFormat Classes |
 *
 *	These classes are derived from the RichEdit 1.0 CHARFORMAT and PARAFORMAT
 *	structures and are the RichEdit 2.0 internal versions of these structures.
 *	Member functions (like Copy()) that use external (API) CHARFORMATs and
 *	PARAFORMATs need to check the <p cbSize> value to see what members are
 *	defined.  Default values that yield RichEdit 1.0 behavior should be stored
 *	for RichEdit 1.0 format structures, e.g., so that the renderer doesn't do
 *	anomalous things with random RichEdit 2.0 format values.  Generally the
 *	appropriate default value is 0.
 *
 *	All character and paragraph format measurements are in twips.  Undefined
 *	mask and effect bits are reserved and must be 0 to be compatible with
 *	future versions.
 *
 *	Effects that appear with an asterisk (*) are stored, but won't be
 *	displayed by RichEdit 2.0.  They are place holders for TOM and/or Word
 *	compatibility.
 *
 *	Note: these structures are much bigger than they need to be for internal
 *	use especially if we use SHORTs instead of LONGs for dimensions and
 *	the tab and font info are accessed via ptrs.  Nevertheless, in view of our
 *	tight delivery schedule, RichEdit 2.0 uses the classes below.
 *
 *	History:
 *		9/1995	-- MurrayS: Created
 *		11/1995 -- MurrayS: Extended to full Word97 FormatFont/Format/Para
 *
 */

#ifndef _CFPF_H
#define _CFPF_H

LONG	GetUsableFontHeight(LONG ySrcHeight, LONG lPointChange);
BOOL	IsValidCharFormat (const CHARFORMAT *	pCF);
BOOL	IsValidCharFormatA(const CHARFORMATA *	pCFA);
BOOL	IsValidParaFormat (const PARAFORMAT *	pPF);

//FUTURE (murrays): include in dwEffects2 of CHARFORMAT3
//#define	CFM_DELETED			0x4000
//#define	CFE_DELETED			CFM_DELETED


// CParaFormat Style enums and defines (maybe move to richedit.h?)
enum STYLES
{
	STYLE_NORMAL	= -1,
	STYLE_HEADING_1	= -2,
	STYLE_HEADING_9	= -10
};

#define	NHSTYLES				9			// # of heading styles
#define	STYLE_COMMAND			0x8000
#define TWIPS_PER_POINT			20

#define IsHeadingStyle(Style)	(Style <= STYLE_HEADING_1 && \
								 Style >= STYLE_HEADING_9)
#define IsKnownStyle(Style)		(IsHeadingStyle(Style) || Style == STYLE_NORMAL)
#define IsStyleCommand(Style)	((Style & 0xFF00) == STYLE_COMMAND)

#define CCHMAXNUMTOSTR			11			// Enuf for 4 billion + null term

typedef struct _styleformat
{
	BYTE	bEffects;
	BYTE	bHeight;
} STYLEFORMAT;

/*
 *	Tab Structure Template
 *
 *	To help keep the size of the tab array small, we use the two high nibbles
 *	of the tab LONG entries in rgxTabs[] to give the tab type and tab leader
 *	(style) values.  The measurer and renderer need to ignore (or implement)
 *	these nibbles.  We also need to be sure that the compiler does something
 *	rational with this idea...
 */

typedef struct tagTab
{
	DWORD	tbPos		: 24;	// 24-bit unsigned tab displacement
	DWORD	tbAlign		: 4;	// 4-bit tab type  (see enum PFTABTYPE)
	DWORD	tbLeader	: 4;	// 4-bit tab style (see enum PFTABSTYLE)
} TABTEMPLATE;

enum PFTABTYPE					// Same as tomAlignLeft, tomAlignCenter,
{								//  tomAlignRight, tomAlignDecimal, tomAlignBar
	PFT_LEFT = 0,				// ordinary tab
	PFT_CENTER,					// center tab
	PFT_RIGHT,					// right-justified tab
	PFT_DECIMAL,				// decimal tab
	PFT_BAR						// Word bar tab (vertical bar)
};

enum PFTABSTYLE					// Same as tomSpaces, tomDots, tomDashes,
{								//  tomLines
	PFTL_NONE = 0,				// no leader
	PFTL_DOTS,					// dotted
	PFTL_DASH,					// dashed
	PFTL_UNDERLINE,				// underlined
	PFTL_THICK,					// thick line
	PFTL_EQUAL					// double line
};

#define PFT_DEFAULT		0xff000000
#define cbSkipFormat	(sizeof(UINT) + sizeof(DWORD))

#define CopyFormat(pfDst, pfSrc, cb) \
			CopyMemory(((LPBYTE) (pfDst)) + cbSkipFormat, \
				((LPBYTE) (pfSrc)) + cbSkipFormat, (cb) - cbSkipFormat)


//
// INTERNAL EFFECT FLAGS
//
#define CFMI_RUNISDBCS		0x1						// indicates that text run is 
#define CFEI_RUNISDBCS		CFMI_RUNISDBCS			// DBCS stuffed into Unicode buffer

#define CFMI_FACENAMEISDBCS	0x2						// indicates that szFaceName is DBCS 
#define CFEI_FACENAMEISDBCS	CFMI_FACENAMEISDBCS		// stuffed into Unicode buffer

/*
 *	CCharFormat
 *
 *	@class
 *		Collects related CHARFORMAT methods and inherits from CHARFORMAT2
 *
 *	@devnote
 *		Could add extra data for round tripping RTF and TOM info, e.g.,
 *		save style handles. This data wouldn't be exposed at the API level.
 */
class CCharFormat : public CHARFORMAT2
{
public:
	BYTE	bCRC;					// Reserved for CRC for rapid searching
	union
	{
		WORD	wInternalFlags;
		struct
		{
			BYTE	bInternalMask;			
			BYTE	bInternalEffects;	
		};
	};

	CCharFormat();
													//@cmember Apply *<p pCF>
	HRESULT	Apply (const CCharFormat *pCF,			//  to this CCharFormat
				   BOOL bInOurHost);
	void	ApplyDefaultStyle (LONG Style);

	BOOL	Compare	(const CCharFormat *pCF) const;	//@cmember Compare this CF
													//  to *<p pCF>
	void	Delta (CCharFormat *pCF) const ;		//@cmember Set difference
													//  mask between this and
													//  *<p pCF>
	BOOL	fSetStyle() const;
	void	Get (CCharFormat *pCF) const;			//@cmember Same as Get(CF*) but
													//	copies CCF members as well
	BOOL	GetA(CHARFORMATA *pCFA) const;			//@cmember Copy this CF to
													//  the ANSI CF *<p pCFA>
	HRESULT	InitDefault (HFONT hfont);				//@cmember Initialize using
													//  font info from <p hfont>
	void	Set (const CHARFORMAT *pCF);			//@cmember Copy *<p pCF> 
													//  to this CF
	void	Set (const CCharFormat *pCF);			//@cmember Same as Set(CF*) but
													//	copies CCF members as well
	BOOL	SetA(CHARFORMATA *pCFA);				//@cmember Copy the ANSI CF 
													//  *<p pCFA> to this CF
	void	SetCRC();								//@cmember Set search CRC.
};

/*
 *	CParaFormat
 *
 *	@class
 *		Collects related PARAFORMAT methods and inherits from PARAFORMAT2
 *
 *	@devnote
 *		Could add extra data for round tripping RTF and TOM info, e.g., to
 *		save style handles
 */

class CParaFormat : public PARAFORMAT2
{
public:
	DWORD	dwBorderColor;							//@cmember Colors/attribs

	CParaFormat();
													//@cmember Add tab at
	HRESULT	AddTab (LONG tabPos, LONG tabType,		// position <p tabPos>
					LONG tabStyle, BOOL fInTable);
	HRESULT	Apply (const CParaFormat *pPF);			//@cmember Apply *<p pPF>
													//  to this CParaFormat
	void	ApplyDefaultStyle (LONG Style);
	BOOL	Compare	(const CParaFormat *pPF) const;	//@cmember Compare this PF
													//  to *<p pPF>
	HRESULT	DeleteTab (LONG tabPos);				//@cmember Delete tab at
													//  <p tabPos>
	void	Delta (CParaFormat *pPF) const;			//@cmember Set difference
													//  mask between this and
													//  *<p pPF>
	BOOL	fSetStyle() const;
	void	Get (CParaFormat *pPF) const;			//@cmember Copy this PF to
													//  *<p pPF>
	char	GetOutlineLevel(){return bOutlineLevel;}
													//@cmember Get tab position
	HRESULT	GetTab (long iTab, long *pdxptab,		// type, and style
					long *ptbt, long *pstyle) const;
	
	BOOL	HandleStyle(LONG Mode);					//@cmember Handle sStyle
													//@cmember Initialize this
	HRESULT	InitDefault (LONG lDefTab,				//  PF to default values
						 WORD wDefEffects = 0);
													
	BOOL	InTable() const			{return (wEffects & PFE_TABLE) != 0;}
	BOOL	IsListNumbered() const	{return IN_RANGE(tomListNumberAsArabic,
												 wNumbering,
												 tomListNumberAsSequence);}
	BOOL	IsNumberSuppressed() const
					{return (wNumberingStyle & 0xF00) == PFNS_NONUMBER;}
	LONG	NumToStr(TCHAR *pch, LONG n) const;
													//@cmember Copy *<p pPF>
	void	Set (const PARAFORMAT *pPF);			//  to this PF
	void	Set (const CParaFormat *pPF)	{*this = *pPF;}
	LONG	UpdateNumber (LONG n, const CParaFormat *pPF) const;
};													 

#define	GetTabPos(tab)		((tab) & 0xffffff)
#define	GetTabAlign(tab)	(((tab) >> 24) & 0xf)
#define	GetTabLdr(tab)		((tab) >> 28)

#endif

/*	FUTURE: Possible Table Storage Layout:
 *
 *	A table could be stored as a sequence of paragraphs with special
 *	characteristics. Each table row starts with a table-row paragraph whose
 *	properties identify the row properties: alignment, StartIndent, line
 *	spacing, line spacing rule, PFE_KEEP and PFE_RTLPARA bits, and border
 *	info, which all work the same way for the row that they work for an
 *	ordinary paragraph.  The offset	field gives the half-gap space between
 *	cells in the row.  A table-row paragraph is identified by the PFM_TABLE
 *	mask field equal to PFE_ROWSTART.
 *
 *	A paragraph with the PFM_TABLE mask field equal to PFE_TABLECELL is a
 *	paragraph in a table cell, but not the last one in that cell.  The last
 *	paragraph in a cell is identified by PFE_TABLECELLEND.
 */


⌨️ 快捷键说明

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