--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/Symbian3/PDK/Source/GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B.dita Fri Jan 22 18:26:19 2010 +0000
@@ -0,0 +1,203 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- Copyright (c) 2007-2010 Nokia Corporation and/or its subsidiary(-ies) All rights reserved. -->
+<!-- This component and the accompanying materials are made available under the terms of the License
+"Eclipse Public License v1.0" which accompanies this distribution,
+and is available at the URL "http://www.eclipse.org/legal/epl-v10.html". -->
+<!-- Initial Contributors:
+ Nokia Corporation - initial contribution.
+Contributors:
+-->
+<!DOCTYPE concept
+ PUBLIC "-//OASIS//DTD DITA Concept//EN" "concept.dtd">
+<concept id="GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B" xml:lang="en"><title>Image
+Compatibility Use Cases</title><shortdesc>This topic explains the four use cases from which the image compatibility
+guarantees that are provided by the Graphics Resource component derive. </shortdesc><prolog><metadata><keywords/></metadata></prolog><conbody>
+<p> <b>Variant</b>: <xref href="GUID-D93978BE-11A3-5CE3-B110-1DEAA5AD566C.dita">ScreenPlay</xref>. <b>Target
+audience</b>: Device creators. </p>
+<p>The use cases are: </p>
+<ul>
+<li id="GUID-418ED281-C4F1-54FE-8B9A-491B88E99E5B"><xref href="GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B.dita#GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B/GUID-D8B0B3C7-5FC7-5F57-8A9C-2F261DCFCAA9">Constant images</xref></li>
+<li id="GUID-DE1565D6-2300-567A-AFD4-EAF20BCD40FC"><xref href="GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B.dita#GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B/GUID-6F77A653-5150-5515-A185-D883BCE84368">Application-level CPU rendering</xref></li>
+<li id="GUID-9B18F4F9-6ED3-5A97-B17C-6A006B6562C5"><xref href="GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B.dita#GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B/GUID-FABC1276-E9D5-567D-B283-76475D2C8359">Off-screen rendering</xref></li>
+<li id="GUID-E1C783A5-890B-5413-BC52-FC1C4FBBE559"><xref href="GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B.dita#GUID-12BB6113-216F-53BB-85FE-E14A6A6A2F8B/GUID-8EE28379-94E9-5029-9995-11CAE9D2D89A">UI surface rendering</xref></li>
+</ul>
+<section id="GUID-D8B0B3C7-5FC7-5F57-8A9C-2F261DCFCAA9"><title> Constant images </title> <p>A
+constant image is not modified after creation. A typical example of a constant
+image is an icon that is loaded from a file and does not change. </p> <p>A
+constant image has the following guaranteed set of attributes: </p> <ul>
+<li id="GUID-92AFB961-628D-5717-851B-5D15208A2219"><p>The image cannot be
+changed. </p> </li>
+<li id="GUID-86C067BD-3A1D-5CA9-9B14-3B687CDD5C50"><p>Applications cannot
+have direct access to the pixels (no CPU access). </p> </li>
+<li id="GUID-0B8693D6-1DD7-5857-ABE3-79894B7849E7"><p>The image may only be
+used as a source for DirectGDI* or <xref href="GUID-0AEE5955-C530-35F1-A904-69183331B294.dita"><apiname>CWindowGc</apiname></xref> rendering. </p> </li>
+<li id="GUID-E9B32C32-E752-5774-A389-8A64578FB3AE"><p>The screen ID can be
+-1 or the ID of a screen on the phone. For example, on a device that has a
+single screen, it can be -1 or 0. -1 indicates "screen agnostic", which means
+that the image can be rendered on any screen. This is the only use case for
+which this is guaranteed. </p> </li>
+<li id="GUID-F8CF2787-F718-5BB0-AD85-F4FC809C28DA"><p>The pixel size can be
+any size, subject to memory available for use. </p> </li>
+<li id="GUID-01058E49-F28C-5B7A-8D87-13AA11F1D189"><p>The image may be sharable
+or non-sharable. </p> </li>
+</ul> <p>A constant image is one that is created with no request for CPU write
+access and no request for use as a rendering target. For more information,
+see <xref href="GUID-FE0BB820-00B3-3E13-907A-FAFB2D20D43B.dita"><apiname>TSgImageInfo</apiname></xref>. </p> <p>This use case covers images created
+using <codeph>RSgImage::Create()</codeph> where the user provides the initial
+data. </p> <p>The pixel formats supported for this use case are: </p> <table id="GUID-35174611-684B-5506-A511-96D5F9CB45EF">
+<tgroup cols="1"><colspec colname="col0"/>
+<tbody>
+<row>
+<entry><p> <codeph>EUidPixelFormatARGB_8888_PRE</codeph></p> </entry>
+</row>
+<row>
+<entry><p><codeph>EUidPixelFormatXRGB_8888</codeph> </p> </entry>
+</row>
+<row>
+<entry><p> <codeph>EUidPixelFormatARGB_8888</codeph></p> </entry>
+</row>
+<row>
+<entry><p> <codeph>EUidPixelFormatRGB_565</codeph></p> </entry>
+</row>
+</tbody>
+</tgroup>
+</table> <p>* If DirectGDI is present on the platform. </p> </section>
+<section id="GUID-6F77A653-5150-5515-A185-D883BCE84368"><title> Application-level
+CPU rendering </title> <p>This use case corresponds to an image that is modified
+directly by an application, without the use of rendering functions provided
+by the platform. For example, a game that uses its own rendering functions. </p> <p>The
+set of guaranteed attributes for this type of image are: </p> <ul>
+<li id="GUID-59B85742-F5F5-5930-931B-9A3B487F2209"><p>The image can be changed
+(it is mutable). </p> </li>
+<li id="GUID-B1252595-8891-5A86-B004-D307FC518B5F"><p>The application can
+have direct read and write access to the pixel data. </p> </li>
+<li id="GUID-B2F732B6-EC1E-5D11-912B-38025979681A"><p>Support is only guaranteed
+for usage as a source for DirectGDI* or <xref href="GUID-0AEE5955-C530-35F1-A904-69183331B294.dita"><apiname>CWindowGc</apiname></xref> rendering. </p> </li>
+<li id="GUID-444F5D1F-FE88-59E9-8844-35EC97A10B25"><p>Support is only guaranteed
+if the image is tied to one screen. The screen ID must therefore be the actual
+ID of one of the screens on the device. If the image needs to be used on multiple
+screens, multiple copies of the image may be required. </p> </li>
+<li id="GUID-A1522C8E-57F6-5A08-884F-60A3586876D8"><p>The image size (size
+in pixels) is limited only by memory availability. </p> </li>
+<li id="GUID-0746CAB1-3181-5998-B8F4-48F2A037CA71"><p>The image may be sharable
+or non-sharable. </p> </li>
+</ul> <p>To allow the CPU to access the pixel data, a developer can use the
+following functions: </p> <table id="GUID-DA69A90D-0517-569B-9B7E-3C8562AEC8FF">
+<tgroup cols="2"><colspec colname="col0"/><colspec colname="col1"/>
+<tbody>
+<row>
+<entry><p> <xref href="GUID-EDC0E03F-37F6-3BEC-8FF3-D03C3CDB949C.dita#GUID-EDC0E03F-37F6-3BEC-8FF3-D03C3CDB949C/GUID-73EDBD53-DA17-32B7-9DE3-E151EAC5EDE0"><apiname>RSgImage::MapReadOnly()</apiname></xref> </p> </entry>
+<entry><p>Makes pixel data accessible for reading by the CPU </p> </entry>
+</row>
+<row>
+<entry><p> <xref href="GUID-EDC0E03F-37F6-3BEC-8FF3-D03C3CDB949C.dita#GUID-EDC0E03F-37F6-3BEC-8FF3-D03C3CDB949C/GUID-7BB75B50-5EF0-3AB1-B44E-4756CDCB98C9"><apiname>RSgImage::MapWriteOnly()</apiname></xref> </p> </entry>
+<entry><p>Makes pixel data accessible for writing by the CPU </p> </entry>
+</row>
+<row>
+<entry><p> <xref href="GUID-EDC0E03F-37F6-3BEC-8FF3-D03C3CDB949C.dita#GUID-EDC0E03F-37F6-3BEC-8FF3-D03C3CDB949C/GUID-9AF1743D-BB04-3F02-B5C7-2AB6FE2EA3DC"><apiname>RSgImage::MapReadWrite()</apiname></xref> </p> </entry>
+<entry><p>Makes pixel data accessible for reading and writing by the CPU </p> </entry>
+</row>
+<row>
+<entry><p> <xref href="GUID-EDC0E03F-37F6-3BEC-8FF3-D03C3CDB949C.dita#GUID-EDC0E03F-37F6-3BEC-8FF3-D03C3CDB949C/GUID-A4549751-8EDE-3202-8C97-E83A5DA96B59"><apiname>RSgImage::Unmap()</apiname></xref> </p> </entry>
+<entry><p>Makes pixel data not accessible for reading or writing by the CPU </p> </entry>
+</row>
+</tbody>
+</tgroup>
+</table> <p>The pixel formats supported for this use case are: </p> <table id="GUID-6EF641DF-4E27-50AD-9944-30530E90B480">
+<tgroup cols="1"><colspec colname="col0"/>
+<tbody>
+<row>
+<entry><p> <codeph>EUidPixelFormatARGB_8888_PRE</codeph> </p> </entry>
+</row>
+<row>
+<entry><p> <codeph>EUidPixelFormatXRGB_8888</codeph> </p> </entry>
+</row>
+<row>
+<entry><p> <codeph>EUidPixelFormatRGB_565</codeph> </p> </entry>
+</row>
+</tbody>
+</tgroup>
+</table> <p>* If DirectGDI is present on the platform. </p> </section>
+<section id="GUID-FABC1276-E9D5-567D-B283-76475D2C8359"><title>Off-screen
+rendering</title> <p>This use case corresponds to images that are used to
+store the results of rendering pipelines provided by the platform; for example
+DirectGDI, OpenGLES or OpenVG. </p> <p>The set of guaranteed attributes for
+this type of image are: </p> <ul>
+<li id="GUID-033AB275-3620-5450-9197-DEB511AB05ED"><p>The image can be changed
+(it is mutable) </p> </li>
+<li id="GUID-8E34E82E-84E6-5B3D-A20E-363328248418"><p>The application cannot
+have direct access to the pixels on the image to read or write (no CPU access) </p> </li>
+<li id="GUID-94C54C9A-AC49-5043-A052-447A37A72ACB"><p>The image can be used
+as a: </p> <ul>
+<li id="GUID-56F5941B-8197-505E-B086-685DA4F0BFB0"><p>Target for DirectGDI*,
+OpenGLES** or OpenVG*** rendering. </p> </li>
+<li id="GUID-13AD417E-70FE-56E2-B708-35CDD61896F7"><p>Source for DirectGDI*
+or <xref href="GUID-FE0BB820-00B3-3E13-907A-FAFB2D20D43B.dita"><apiname>CWindowGc</apiname></xref> rendering. </p> </li>
+</ul> </li>
+<li id="GUID-96F8EF27-E215-5A23-A4B5-44CCBBF609F3"><p>Support is only guaranteed
+if the image is tied to one screen. The screen ID must therefore be the actual
+ID of one of the screens on the device. If the image needs to be used on multiple
+screens, multiple copies of the image may be required. </p> </li>
+<li id="GUID-D927209A-6913-52E2-9571-2153C74AC937"><p>The image size (in pixels)
+is limited only by memory availability </p> </li>
+<li id="GUID-EB99D1C1-7462-5A7C-9DFB-BB753C119236"><p>The image may be sharable
+or non-sharable. </p> </li>
+</ul> <p>The pixel formats supported for this use case are: </p> <table id="GUID-90B13F9C-EAFB-5BD7-80B2-6AC1C8695EBA">
+<tgroup cols="1"><colspec colname="col0"/>
+<tbody>
+<row>
+<entry><p>At least one RGB format <b>with an alpha channel</b>, and a minimum
+of 8 bits per channel. Channel ordering is not specified </p> </entry>
+</row>
+<row>
+<entry><p>At least one RGB format <b>with no alpha channel</b>, and a minimum
+of 8 bits per channel. Channel ordering is not specified. </p> </entry>
+</row>
+</tbody>
+</tgroup>
+</table> <p>* If DirectGDI is present on the platform. </p> <p>** If OpenGL
+ES is present on the platform. </p> <p>*** If OpenVG is present on the platform. </p> </section>
+<section id="GUID-8EE28379-94E9-5029-9995-11CAE9D2D89A"><title> UI surface
+rendering </title> <p>This use case corresponds to an image that is created
+by the Window Server to transfer UI rendering into the <xref href="GUID-0DC3E5AA-1706-5255-ACD6-E7AB732E1095.dita">composition
+engine</xref>. This use case only applies to the creation of <xref href="GUID-FE0BB820-00B3-3E13-907A-FAFB2D20D43B.dita"><apiname>RSgImageCollection</apiname></xref> instances. </p> <p>The
+set of guaranteed attributes for this type of image are: </p> <ul>
+<li id="GUID-B1973F49-7495-5893-B07E-8B76960112C9"><p>The image can be changed
+(it is mutable) </p> </li>
+<li id="GUID-B1BE0B2C-E47F-5362-8846-5A5336AD8554"><p>The user does not require
+direct access to the image pixels (no CPU access) </p> </li>
+<li id="GUID-4F329D2C-314D-52A9-BEE6-28B030F6E547"><p>The image can be used
+as a: </p> <ul>
+<li id="GUID-75492618-1372-51CF-8AB7-3A656FCF4A09"><p>Target for DirectGDI*,
+OpenGLES** or OpenVG*** rendering </p> </li>
+<li id="GUID-30826072-D8F2-576E-9FD0-A572EE92C429"><p>Composition source,
+which means that it is used as input to the composition engine </p> </li>
+<li id="GUID-96567159-5753-5792-BA25-E352603676D1"><p>Screen source, which
+means that the display hardware can read it directly </p> </li>
+</ul> </li>
+<li id="GUID-C0777DB4-904F-5477-90F2-E680783BF5F8"><p>Support is only guaranteed
+if the image is tied to one screen. The screen ID must therefore be the actual
+ID of one of the screens on the device. </p> </li>
+<li id="GUID-B5F4FC50-732E-546B-AFDA-9E4B787E5D51"><p>The image size must
+be supported by the specified screen. </p> </li>
+<li id="GUID-175F2884-02D9-5D27-840E-466CEBFADA1C"><p>The image is not shareable
+between processes. </p> </li>
+</ul> <p>The pixel formats supported for this use case are: </p> <table id="GUID-1B522269-38E0-5F09-8909-AF2C2AF22048">
+<tgroup cols="1"><colspec colname="col0"/>
+<tbody>
+<row>
+<entry><p>At least one RGB format <b>with an alpha channel</b>, and a minimum
+of 8 bits per channel. Channel ordering is not specified. </p> </entry>
+</row>
+</tbody>
+</tgroup>
+</table> <p>* If DirectGDI is present on the platform. </p> <p>** If OpenGL
+ES is present on the platform. </p> <p>*** If OpenVG is present on the platform. </p> </section>
+</conbody><related-links>
+<link href="GUID-29C7FBFB-2F33-58CA-86BE-978E3187E4D6.dita"><linktext>Image Compatibility
+Guarantees</linktext></link>
+<link href="GUID-69E426EC-CDBB-5B19-8264-050EB93B9315.dita"><linktext>Supported
+Image Formats</linktext></link>
+<link href="GUID-610C1484-112E-5442-95DC-89CF890A8310.dita"><linktext>Pixel Formats</linktext>
+</link>
+</related-links></concept>
\ No newline at end of file