STM32+Grlib

源代码在线查看: context.c

软件大小: 5897 K
上传用户: zkflsq
关键词: Grlib STM 32
下载地址: 免注册下载 普通下载 VIP

相关代码

				//*****************************************************************************
				//
				// context.c - Routines for handling drawing contexts.
				//
				// Copyright (c) 2007-2010 Texas Instruments Incorporated.  All rights reserved.
				// Software License Agreement
				// 
				// Texas Instruments (TI) is supplying this software for use solely and
				// exclusively on TI's microcontroller products. The software is owned by
				// TI and/or its suppliers, and is protected under applicable copyright
				// laws. You may not combine this software with "viral" open-source
				// software in order to form a larger program.
				// 
				// THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
				// NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
				// NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
				// A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
				// CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
				// DAMAGES, FOR ANY REASON WHATSOEVER.
				// 
				// This is part of revision 5821 of the Stellaris Graphics Library.
				//
				//*****************************************************************************
				
				#include "driverlib/debug.h"
				#include "grlib/grlib.h"
				
				//*****************************************************************************
				//
				//! \addtogroup primitives_api
				//! @{
				//
				//*****************************************************************************
				
				//*****************************************************************************
				//
				//! Initializes a drawing context.
				//!
				//! \param pContext is a pointer to the drawing context to initialize.
				//! \param pDisplay is a pointer to the tDisplayInfo structure that describes
				//! the display driver to use.
				//!
				//! This function initializes a drawing context, preparing it for use.  The
				//! provided display driver will be used for all subsequent graphics
				//! operations, and the default clipping region will be set to the extent of
				//! the screen.
				//!
				//! \return None.
				//
				//*****************************************************************************
				void
				GrContextInit(tContext *pContext, const tDisplay *pDisplay)
				{
				    //
				    // Check the arguments.
				    //
				    ASSERT(pContext);
				    ASSERT(pDisplay);
				
				    //
				    // Set the size of the context.
				    //
				    pContext->lSize = sizeof(tContext);
				
				    //
				    // Save the pointer to the display.
				    //
				    pContext->pDisplay = pDisplay;
				
				    //
				    // Initialize the extent of the clipping region to the extents of the
				    // screen.
				    //
				    pContext->sClipRegion.sXMin = 0;
				    pContext->sClipRegion.sYMin = 0;
				    pContext->sClipRegion.sXMax = pDisplay->usWidth - 1;
				    pContext->sClipRegion.sYMax = pDisplay->usHeight - 1;
				
				    //
				    // Provide a default color and font.
				    //
				    pContext->ulForeground = 0;
				    pContext->ulBackground = 0;
				    pContext->pFont = 0;
				}
				
				//*****************************************************************************
				//
				//! Sets the extents of the clipping region.
				//!
				//! \param pContext is a pointer to the drawing context to use.
				//! \param pRect is a pointer to the structure containing the extents of the
				//! clipping region.
				//!
				//! This function sets the extents of the clipping region.  The clipping region
				//! is not allowed to exceed the extents of the screen, but may be a portion of
				//! the screen.
				//!
				//! The supplied coordinate are inclusive; \e sXMin of 1 and \e sXMax of 1 will
				//! define a clipping region that will display only the pixels in the X = 1
				//! column.  A consequence of this is that the clipping region must contain
				//! at least one row and one column.
				//!
				//! \return None.
				//
				//*****************************************************************************
				void
				GrContextClipRegionSet(tContext *pContext, tRectangle *pRect)
				{
				    unsigned long ulW, ulH;
				
				    //
				    // Check the arguments.
				    //
				    ASSERT(pContext);
				    ASSERT(pRect);
				
				    //
				    // Get the width and height of the display.
				    //
				    ulW = DpyWidthGet(pContext->pDisplay);
				    ulH = DpyHeightGet(pContext->pDisplay);
				
				    //
				    // Set the extents of the clipping region, forcing them to reside within
				    // the extents of the screen.
				    //
				    pContext->sClipRegion.sXMin = ((pRect->sXMin < 0) ? 0 :
				                                   ((pRect->sXMin >= ulW) ? (ulW - 1) :
				                                    pRect->sXMin));
				    pContext->sClipRegion.sYMin = ((pRect->sYMin < 0) ? 0 :
				                                   ((pRect->sYMin >= ulH) ? (ulH - 1) :
				                                    pRect->sYMin));
				    pContext->sClipRegion.sXMax = ((pRect->sXMax < 0) ? 0 :
				                                   ((pRect->sXMax >= ulW) ? (ulW - 1) :
				                                    pRect->sXMax));
				    pContext->sClipRegion.sYMax = ((pRect->sYMax < 0) ? 0 :
				                                   ((pRect->sYMax >= ulH) ? (ulH - 1) :
				                                    pRect->sYMax));
				}
				
				//*****************************************************************************
				//
				// Close the Doxygen group.
				//! @}
				//
				//*****************************************************************************
							

相关资源