The present invention relates to a display controller and an image display method for causing a display device to display images.
Hitherto, there have been developed various techniques for enhancing image quality of video display such as television broadcasting or distributed moving images. In recent years, in addition to techniques for enhancing resolution or color gamut, techniques for processing HDR (High Dynamic Range) signals in the expanded luminance range have been becoming popular. HDR is approximately one hundred times as large as SDR (Standard Dynamic Range) in the related art in luminance allowable range. Thus, dazzling objects in the real world such as the reflected light of sunlight can be represented more realistically even on images. Not only in television broadcasting or distributed moving images, but also in computer graphics worlds such as game images, more immersive virtual worlds are given through HDR representation (for example, see PTL 1).
[PTL 1] Japanese Patent Laid-open No. 2016-58848
There are various combinations of conditions such as a luminance range that defines original image data and a luminance range that a connected display supports, so that more complex processing is required for image display. In particular, in a case where a plurality of images are combined to be displayed, different composite results are obtained depending on a change in conditions as described above, with the result that an image not originally intended to be displayed is displayed in some cases.
The present invention has been made in view of such a problem and has an object to provide a technique for achieving appropriate control of the composite result of a plurality of images, which are combined to be displayed, irrespective of conditions.
An aspect of the present invention relates to a display controller. The display controller includes a plurality of combining-use conversion circuits configured to convert a plurality of data on a plurality of images read from a memory to a plurality of data having a common characteristic in terms of luminance, a combining circuit configured to perform alpha blending on the data on the plurality of images having the common characteristic that has been output from the combining-use conversion circuits, and an output-use conversion circuit configured to output data on a composite image as a signal for display.
Another aspect of the present invention relates to an image display method. The image display method includes causing a display controller to execute the steps of converting data on a plurality of images read from a memory to data having a common characteristic in terms of luminance, performing alpha blending on the data on the plurality of images having the common characteristic, and outputting data on a composite image as a signal for display to a display.
Note that, any combinations of the above-mentioned components as well as modes obtained by converting the expressions of the present invention between a method, a device, a system, a computer program, a recording medium having recorded thereon a computer program, and the like are also effective as modes of the present invention.
According to the present invention, the composite result of a plurality of images, which are combined to be displayed, can be appropriately controlled irrespective of conditions.
The display 16 is implemented by, for example, a liquid crystal display, plasma display, or organic EL (electroluminescence) display configured to display images. Moreover, the display 16 may include a speaker configured to output sound. The input device 14 and the display 16 may be connected to the information processing device 10 with a cable or wirelessly through a wireless LAN (Local Area Network) or the like. Further, the appearance shapes of the input device 14, the display 16, and the information processing device 10 are not limited to those illustrated in
The information processing device 10 receives a signal based on the user's operation from the input device 14, performs processing based on the signal to generate data on a display image, and outputs the data to the display 16. The information processing device 10 may be any of a game console, a personal computer, a tablet terminal, a mobile terminal, a mobile phone, and the like. The processing details of the information processing device 10 may vary depending on the modes of the information processing device 10, applications selected by the user, or the like.
For example, the information processing device 10 causes an electronic game specified by the user, to progress, on the basis of the user's operation, generates game screen data at a predetermined frame rate, and outputs the data. Alternatively, the information processing device 10 may acquire moving image data from the server via the network 8 and decode and output the data sequentially. In this way, the information processing device 10 may be used for various purposes, and the details of information processing to be performed vary depending on usage purposes, so that a detailed description thereof is omitted. In the following, a method for preferably displaying content images generated as a result of such information processing, images representing information to be presented, or the like is described mainly.
At this time, the region of the main image 200a that is visible through the additional image 200b is set as wide as possible so that the necessary information can be preferably fused with little interference with the world of the main image 200a such as a game or moving image. Moreover, by changing the transparency of the additional image 200b over time, an effect in which the dialog box gradually appears or disappears can be provided.
It should be understood by those skilled in the art that, as the case in which a plurality of images are superimposed to be displayed, various cases are considerable other than the example illustrated in
In a case where the display image 202 is generated, a color value Cout of each pixel of the display image 202 can be determined using a calculation with alpha blending represented by the following formula.
Cout=(1−α)C1+αC2 (Formula 1)
Here, C1 represents the color value of a corresponding pixel of the main image 200a, C2 represents the color value of a corresponding pixel of the additional image 200b, and a is a general a value that is set for the pixel of the additional image 200b, namely, a value equal to or larger than 0 but equal to or smaller than 1.0 indicating transparency.
For example, when the a value is changed from 0 to 1.0 in the entire image, from a state in which only the main image 200a is displayed, the colors of the additional image 200b are gradually deepened and the opaque additional image 200b is eventually displayed. When the a value is set to an intermediate value larger than 0 and smaller than 1.0, the additional image 200b is translucent at a level based on the numerical value but the main image 200 is seen through the additional image 200b.
Note that, when the main image 200a and the additional image 200b are RGB images, the color values C1 and C2 are set to each of the three channels, and in the present embodiment, those values are collectively referred to as “color values C1 and C2.” Further, the color values C1 and C2 and the a value are each set in units of pixels, and thus depend on two-dimensional position coordinates (x, y) on the image plane in a precise sense. In Formula 1, however, a calculation for pixels at the same position is assumed, so that the position coordinates are not described. The same holds true for the following.
The CPU 22 controls the entire information processing device 10 by executing an operating system stored in the storage section 34. The CPU 22 also executes various programs read from the removable recording medium to be loaded on the main memory 26 or downloaded via the communication section 32. Further, the communication section 32 may establish communication with an external device such as the server via the network 8, to thereby acquire data on electronic content such as moving images or transmit data generated in the information processing device 10.
The main memory 26 includes a RAM (Random Access Memory). The main memory 26 includes frame buffers 70a and 70b configured to store image data to be displayed. However, the number of frame buffers is not limited to any specific number. The image data to be stored includes an a plane in which the a value for alpha blending is represented on the image plane. The a value may be set in units of pixels or regions, or may be a fixed value for an entire image. Further, the set value may be changed over time. Further, the main memory 26 also stores programs or data necessary for processing.
The GPU 24 has a geometry engine function and a rendering processor function, and performs drawing processing in response to a drawing command from the CPU 22 and stores data on the image in the frame buffer 70a or 70b. The display controller 36 acquires data on images from the frame buffers 70a and the like, and outputs the data to the display 16 as a video signal at an appropriate timing. The display controller 36 also performs the image combining processing as described above, as needed.
The display controller 36 reads the video signal from the frame buffer 70a and supplies the video signal to the display 16. The display 16 converts the video signal to luminance values with an EOTF (electro-optical transfer function) as illustrated in (c). By appropriately selecting the EOTF, from signals having the same color depth, luminance values in different ranges, namely, a range of from 0 to 100 nits for SDR images and a range of from 0 to 10,000 nits for HDR images, for example, are obtained in units of pixels. The luminance values are further corrected on the basis of the luminance characteristics of the display panel to be sequentially output at appropriate timing, so that the images are displayed in the corresponding luminance range.
Further, (b) illustrates a case where a display configured to support the luminance range of HDR is connected and the first image is generated in HDR. Meanwhile, the second image is generated in SDR as described above. The display controller 36 accordingly converts the luminance range of the second image to values in HDR and substitutes the resultant into Formula 1, to thereby acquire the color values of the composite image. The luminance range conversion from SDR to HDR is achieved by mapping the luminance range of SDR to a part of the luminance range of HDR. For example, the peak luminance of SDR (1.0) is associated with a brightness of approximately 260 nits, and values of from 0 to 1.0 in SDR are mapped in a range of from 0 to 260 nits in HDR. However, the brightness to be associated is not limited to any particular brightness.
In (b), a signal represented in the luminance range of HDR is indicated by the thick line, and a signal represented in the luminance range of SDR is indicated by the thin line. However, the display controller 36 reads values quantized with the OETF described above so that when two images to be combined are converted with different OETFs, the composite result is affected by the conversion. This may occur irrespective of whether the luminance range is SDR or HDR. The principle of this is described below.
Formula 1 generally assumes the pixel value P but a similar result is obtained by combining, with Formula 1, color values in the linear space converted with the linear formula illustrated in (a). Meanwhile, the characteristics of the color value C of images converted with the nonlinear function illustrated in (b) are changed depending on the range of the pixel value P. Such nonlinear conversion affects combining using Formula 1.
For example, regions 50a and 50b in which the scattered light region of the first image depicting a certain scene and the dark region of the second image, which is a system menu, for example, are combined in a translucent manner are compared to each other. The first image is seen through the second image in the case of (a) but is hardly seen in the case of (b). As described above, (a) is similar to the composite result of the original pixel P, but which one of (a) and (b) is preferred depends on applications. For example, the weaker the visual stimulus, the higher the sensitivity of a person to a change in luminance, and hence nonlinear conversion may have a good affinity in terms of vision.
Further, in a case where images generated with different conversion formulae are combined, the composite results may have more various differences. Accordingly, the display controller 36 of the present embodiment converts the color values of images to be combined which are stored in the frame buffers 70a and 70b to values in a common space and then combines the images. The common space here can be specified by an application so that any of the composite images illustrated in (a) and (b) of
Here, the blend space “A” is, for example, the linear space illustrated in (a) of
In a case where the original images stored in the frame buffers 70a and 70b are linear data illustrated in (a) of
When the blend space “A” is the linear space, the color value C (linear) proportional to the output luminance of the display panel can be converted to the color value C (blend space) in the blend space by the following calculation.
C(blend space)=C(linear) (Formula 2)
When the blend space “A” is the gamma space, the color value C (linear) can be converted to the color value C (blend space) by the following calculation.
C(blend space)=(C(linear))(1/γ) (Formula 3)
That is, the color value C (gamma space) in the gamma space and the color value C (linear space) in the linear space can be converted to each other by the following calculations.
C(gamma space)=(C(linear space))(1/γ) (Formula 4)
C(linear space)=(C(gamma space))γ (Formula 5)
The display controller 36 acquires, from the CPU 22, information regarding a blend space specified by an application being executed, and switches between the conversion formulae depending on the information. Then, the display controller 36 combines the two images converted to the common blend space A in units of pixels with Formula 1 (S12). With this, the composite result can be appropriately controlled.
The display controller 36 further converts the composite result to a space suitable for the display 16 (S14). That is, the display controller 36 obtains, from the blend space, the color values proportional to the output luminance of the display panel, and performs inverse conversion with the EOTF illustrated in
That is, the display controller 36 converts these images to data in the common blend space A (S16a and S16b), and then combines the images in units of pixels with Formula 1 (S18). With this, the composite image intended by a developer of the application is generated. Meanwhile, it is desired that even when blend space specification by an application has a degree of freedom, an image provided by the system is not affected by the change. Accordingly, as illustrated in
That is, the display controller 36 converts the third image 56c to the blend space B (S20), and converts the image data obtained by the combining in S18 from the blend space A to the blend space B (S22). Then, the display controller 36 combines the composite image by the application and the third image 56c (S24). The conversion from the blend space A to the blend space B can also be calculated with any of Formulae 2 to 5 descried above. The display controller 36 further converts the composite image obtained in the blend space B to the space suitable for the display 16 (S26), and outputs the resultant.
Considering a difference in luminance range between original images such as SDR and HDR, more various conversion formulae are conceivable.
Thus, as in the above, the characteristics of data converted with the PQ curve are eliminated once, and then the data is converted to a blend space or the like specified by an application to be subjected to the combining processing. Moreover, as described above, depending on a luminance range that a display supports, there is a need of the conversion of HDR images to the luminance range of SDR or the conversion of SDR images to the luminance range of HDR.
In all the cases illustrated in
When detecting that the connected display 16 supports HDR, the display controller 36 converts, of these images stored in the frame buffers, the SDR images to images in the luminance range of HDR (S30a, S30b, and S30c). There is no need of the conversion of HDR images as a matter of course. The display controller 36 further converts the first image 60a and the second image 60b to data in a blend space specified by the application (S32a and S32b). The display controller 36 combines the images in units of pixels with Formula 1 thereafter (S34). In the example illustrated in
Meanwhile, the display controller 36 converts the third image 60c that is subject to further combining to data in a blend space set to the system (S36). In the example illustrated in
In a case where an original image is an HDR image, which has been subjected to conversion with the PQ curve, to eliminate the characteristics of the data once and give characteristics in a blend space to the data, the following formula is used in the case where the blend space is the linear space.
C(blend space)=PQ_EOTF(C(PQ)) (Formula 6)
The following formula is used in the case where the blend space is the gamma space.
C(blend space)=PQ_EOTF(C(PQ))(1/γ) (Formula 7)
Here, C(PQ) is a color value obtained by conversion with the PQ curve, and PQ_EOTF that corresponds to the EOTF of
When detecting that the connected display 16 supports SDR, the display controller 36 converts, of these images stored in the frame buffers, the HDR images to values in the luminance range of SDR (S50a, S50b, and S50c). Then, the display controller 36 converts the first image 62a and the second image 62b to data in a space specified by the application, which is the linear space in the example illustrated in
Meanwhile, the display controller 36 converts the third image 62c that is subject to further combining to a blend space set to the system, which is the gamma space in the example illustrated in
When the procedures of
Note that, the blend spaces illustrated in
The luminance range converting circuits 72a, 72b, 72c, and 72d read, from the respective frame buffers 70a, 70b, 70c, and 70d, image data in units of pixels, and convert, as needed, the values to values in a luminance range that the connected display 16 supports. Further, the luminance range converting circuits 72a, 72b, 72c, and 72d include combining-use conversion circuits 76a, 76b, 76c, and 76d, and convert color values converted to values in the luminance range of the display 16 to values in a predetermined blend space.
The combining circuit 78c adds, with weighting based on the a value, the color values of corresponding pixels output from the luminance range converting circuits 72d and 72c, to thereby calculate the color values of the composite image in a blend space. The combining circuit 78b adds, with weighting, the color values of pixels output from the luminance range converting circuit 72b, and the color values of the pixels of the composite image output from the combining circuit 78c on the former stage, to thereby calculate the color values of the composite image. The combining circuit 78a adds, with weighting, the color values of pixels output from the luminance range converting circuit 72a and the color values of the pixels of the composite image output from the combining circuit 78b on the former stage, to thereby calculate the color values of the composite image.
The combining circuit 78a sequentially outputs the thus obtained ultimate color values of the composite image to the display 16. Here, the combining circuits 78b and 78c include respective composite image converting circuits 80a and 80b, and each convert images obtained by conversion by the combining circuits themselves to a blend space for images to be combined on the latter stage. When a composite image is in the same blend space as images to combined on the latter stage, the processing by the composite image converting circuits 80a and 80b is omitted. In the example illustrated in
Further, the combining circuit 78a includes an output-use conversion circuit 82 and converts the ultimate color values of the pixels of a composite image to values in the space suitable for output to the display 16. The combining-use conversion circuits 76a, 76b, 76c, and 76d, the composite image converting circuits 80a and 80b, and the output-use conversion circuit 82 refer to a look-up table, which is not illustrated, in terms of red, green, and blue values that are the color values of pixels, to thereby perform space conversion by general interpolation circuits. Further, conversion destination blend spaces and whether conversion is required or not in those circuits are controlled by the CPU 22.
According to the present embodiment described above, when a plurality of images are combined by the display controller, the conversion characteristics used for quantization are eliminated once, and the data is given common characteristics for combining to be converted again. With this, it can be prevented that the balance of the pixel values of images to be combined is changed in calculation in general alpha blending due to factors other than the set α value, with the result that a composite image with an unintended degree of transparency is not displayed. Further, a combining space for the combining of images by an application can be specified by the application itself, and the thus obtained composite image is further converted to the space of a separately provided image such as a system image.
With this, images by an application can be more freely combined without affecting system images or the like to be displayed in a superimposed manner. Moreover, data is converted to a combining space after luminance range conversion between SDR and HDR by utilizing the fact that the characteristics themselves are unchanged before and after the luminance range conversion even with a nonlinear conversion formula. With this, even when a display having different performance is connected, composite images independent of the display performance can be stably displayed by easy switching. Combining that supports various conditions can be achieved by the hardware of the display controller such that developers of applications do not need to take various types of user environment into account.
In the above, the present invention has been described on the basis of the embodiment. It should be understood by those skilled in the art that the above-mentioned embodiment is exemplary so that the combinations of components or processing processes of the embodiment can be modified in various ways, and that such modified examples are also within the scope of the present invention.
As described above, the present invention is applicable to, for example, various devices, such as display controllers, display devices, content reproducing devices, and game consoles, and systems including such devices.
8 Network, 10 Information processing device, 14 Input device, 16 Display, 22 CPU, 24 GPU, 26 Main memory, 36 Display controller, 38 Input section, 70a Frame buffer, 72a Luminance range converting circuit, 76a Combining-use conversion circuit, 78a Combining circuit, 80a Composite image converting circuit, 82 Output-use conversion circuit.
Number | Date | Country | Kind |
---|---|---|---|
2019-077972 | Apr 2019 | JP | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2020/013818 | 3/26/2020 | WO |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2020/213367 | 10/22/2020 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
9672603 | Koike | Jun 2017 | B2 |
10192294 | Tsuru | Jan 2019 | B2 |
11006834 | Takahashi | May 2021 | B2 |
20080198170 | Guha | Aug 2008 | A1 |
20120002899 | Orr, IV | Jan 2012 | A1 |
20150213586 | Koike | Jul 2015 | A1 |
20160292834 | Tsuru | Oct 2016 | A1 |
20160365065 | Wu | Dec 2016 | A1 |
20180308269 | Baran | Oct 2018 | A1 |
20190254525 | Takahashi | Aug 2019 | A1 |
20200296323 | Endo | Sep 2020 | A1 |
Number | Date | Country |
---|---|---|
11143441 | May 1999 | JP |
2001239053 | Sep 2001 | JP |
2015141333 | Aug 2015 | JP |
2016058848 | Apr 2016 | JP |
2017182064 | Oct 2017 | JP |
2018055945 | Mar 2018 | WO |
2018088186 | May 2018 | WO |
WO2018088186 | May 2018 | WO |
Entry |
---|
International Search Report for corresponding PCT Application No. PCT/JP2020/013818, 6 pages, dated Jun. 23, 2020. |
Number | Date | Country | |
---|---|---|---|
20220165236 A1 | May 2022 | US |