This disclosure relates generally to display technologies, and in particular but not exclusively, relates to frame timing.
Flat-panel displays have become ubiquitous. They are widely used in digital still cameras, cellular phones, security systems, as well as, medical, automobile, and other applications. Many modern flat-panel displays use backlit liquid crystal technology; however, other types of flat panel displays may use light emitting diodes (LEDs), organic LEDs, plasma panels, electroluminescent panels, or the like.
Flat panel displays may be volatile, meaning that the pixels are periodically refreshed to retain their state even when showing a static image. This refresh may occur many times every second. If the image is not refreshed the pixels may gradually lose their coherent state and the image will fade. Typically, individual rows of pixels that make up the display are refreshed one at a time cycling from one end of the screen to the other.
However, because of different screen sizes and refresh rates, displays may only be compatible with pieces of hardware specifically designed for one screen. Accordingly, image data from one device may not display properly (or at all) if that device is used in conjunction with an incompatible display.
Non-limiting and non-exhaustive examples of the invention are described with reference to the following figures, wherein like reference numerals refer to like parts throughout the various views unless otherwise specified.
Corresponding reference characters indicate corresponding components throughout the several views of the drawings. Skilled artisans will appreciate that elements in the figures are illustrated for simplicity and clarity and have not necessarily been drawn to scale. For example, the dimensions of some of the elements in the figures may be exaggerated relative to other elements to help to improve understanding of various embodiments of the present invention. Also, common but well-understood elements that are useful or necessary in a commercially feasible embodiment are often not depicted in order to facilitate a less obstructed view of these various embodiments of the present invention.
Examples of an apparatus and method for frame timing are described herein. In the following description, numerous specific details are set forth to provide a thorough understanding of the examples. One skilled in the relevant art will recognize, however, that the techniques described herein can be practiced without one or more of the specific details, or with other methods, components, materials, etc. In other instances, well-known structures, materials, or operations are not shown or described in detail to avoid obscuring certain aspects.
Reference throughout this specification to “one example” or “one embodiment” means that a particular feature, structure, or characteristic described in connection with the example is included in at least one example of the present invention. Thus, the appearances of the phrases “in one example” or “in one embodiment” in various places throughout this specification are not necessarily all referring to the same example. Furthermore, the particular features, structures, or characteristics may be combined in any suitable manner in one or more examples.
Throughout this specification, several terms of art are used. These terms are to take on their ordinary meaning in the art from which they come, unless specifically defined herein or the context of their use would clearly suggest otherwise.
In the depicted example, processor 111 is coupled to receive image data 151 from image source 101. Processor 111 is further coupled to output image data 151 and first sync signals 161 to frame timing circuit 121. It is worth noting that first sync signals 161 are periodic, and each one of first sync signals 161 is output after M number of pixel values of image data 151 are output from processor 111.
As stated, frame timing circuit 121 is coupled to processor 111 to receive M number of pixel values of image data 151 and first sync signals 161. Frame timing circuit 121 is also coupled to output X number of pixel values of image data 151 and second sync signals 163 to display 131. In one example, the first sync signals 161 and the second sync signals 163 are horizontal sync signals that are output for each display line. In the depicted example, X number of pixel values is an integer multiple of the M number of pixel values of the image data 151, and each one of second sync signals 163 is output after X number of pixel values of image data 151 are output from frame timing circuit 121. In other words, frame timing circuit 121 may receive several sets of image data 151 from processor 111, with each set of image data 151 containing M number of pixel values. Frame timing circuit 121 will then send out one set of image data 151 (X number of pixel values) containing the several sets of image data 151.
In the illustrated example, register 125 is coupled to store an integer value equal to X/M, and counter 127 is coupled to count a number of first sync signals 161 received by frame timing circuit 121. For instance, in one example X=3840, M=1920, and X/M therefore equals 2. Controller 123 is coupled to register 125 and counter 127, and controller 123 is coupled to update (e.g., via update signal 104) a value stored on counter 127 in response to receiving first sync signals 161. Controller 123 is further coupled to reset counter 127 (via reset signal 102) in response to receiving the integer value of first sync signals 161. Frame timing circuit 121 is coupled to output second sync signals 163 in response to receiving the integer value of first sync signals 161. In one example, the integer value of X/M may be equal to an integer between 1 thorough 4, where the integer is inclusive of 1 and 4. To illustrate by way of example, where frame timing circuit 121 receives three first sync signals 161 and outputs a single second sync signal 163 to display 131, the integer value of X/M is three. In one example, display 131 has dimensions of X by Y and processor 111 is configured to output image data 151 in the form of M by N. Thus the ratio between the processor output and the display resolution is X/M.
Processor 111 may be coupled to frame timing circuit 121 to set the integer value (e.g., X/M) in register 125. Alternatively, controller 123 may be coupled to set the integer value in register 125. In one example, controller 123 may extract the pixel width of display 131 (X) from display 131, and controller 123 may extract the pixel width output (M) from processor 111. In this example, controller 123 may then divide the pixel width of display 131 with the pixel width output of processor 111 (X/M) to set the integer value in register 125. In a different example, the integer value stored on register 125 may be fixed. In one example, the integer value may be fixed during manufacturing of frame timing circuit 121.
In operation, display system 100 allows for an elegant way to convert an image data signal intended to be displayed on a display of one size (M by N pixels) into a data signal to be displayed on a display/screen of a different size (X by Y). In one example, image source 101 is included in display system 100 and image source 101 includes an image sensor. Image source 101 may send image data 151 to processor 111, which may format the data into a format compatible to be displayed on a screen (e.g., add first sync signal 161 to make image data 151 fit the horizontal dimensions of the screen). Frame timing circuit 121 may allow for image data 151 to be reformatted to fit to a screen with different dimensions by removing first sync signal 161 and adding second sync signal 163 at an appropriate interval.
Process block 201 shows sending image data (e.g., image data 151) to processor (e.g., processor 111). In one example, this may include receiving image data from an image source with a processor coupled to the image source.
Process block 203 depicts using the processor to output image data in an M by N pixel value format and output a 1st sync signal for every M pixels per display line. In method 200, the processor outputs the image data and the first sync signals to a frame timing circuit (e.g., frame timing circuit 121). In one example, processor is configured to output the image data to a first display, and the dimensions of the first display are M by N.
Process block 205 illustrates receiving M pixels of image data and the 1st sync signal with a frame timing circuit. In method 200, each one of the first sync signals corresponds to receiving M number of pixel values of the image data.
Process block 207 shows counting the number of first sync signals received, and after receiving each first sync signal, updating a value on the counter (e.g., increment, decrement, register shift, etc.) in response to receiving the first sync signals.
Process block 209 shows comparing the value on the counter and the value of the integer stored in the register. In one example, a controller is used to compare the value stored on the counter to the integer value stored on the register. It is worth noting that the integer value on the register may equal an integer value of X/M. If the value on the counter does not equal the value on the register, then the frame timing circuit will receive M more pixels of image data and again compare the value stored on the counter to the integer value stores on the register. However, when the value stored on the counter equals the integer value stored on the register, the frame timing circuit will output X number of pixel values of the image data to a display (where X is an integer multiple of M), and output a second sync signal. In one example, the integer value of X/M is equal to an integer between 1 thorough 4, where the integer is inclusive of 1 and 4. In other examples, it is appreciated that X/M may be equal to other values.
Process block 211 depicts outputting X number of pixel values of the image data to a display (where X is an integer multiple of M), and outputting a second sync signal. After the second sync signal is output, the counter is reset with a signal from the controller.
Process block 213 shows receiving/displaying X number of pixel values of the image data on a display, where dimensions of the display are X by Y. It should be noted that X number of pixel values of the image data may be displayed on a single image line of the display.
Although in one example, method 200 is occurring in discrete devices, in another example, the controller, the register, and the counter, are included in the frame timing circuit. Further, the image source, processor, frame timing circuit, and display may all be contained in one device (e.g., a cell phone).
Second sync signal 363 is sent from frame timing circuit (e.g., frame timing circuit 121) after the frame timing circuit receives two first synch signals 361 and 3840 pixel values (e.g., X=3840 pixels) of image data. This allows the image data sent from the processor (which should have only been compatible with a 1920×640 pixel display) to be displayed on a screen with a resolution of 3840 by 320 pixels. It should be noted that in the depicted example, the processor outputs a vertical sync (VSYNC) signal after it outputs 640 lines of pixel data. Frame timing circuit may remove this signal and output a second VSYNC signal every 320 lines of the display (e.g., display 131). Frame timing circuit may scale this VSYNC signal adjustment for any display dimensions and processor output. In one example, the VSYNC signal is output every Y lines.
In one example, if a particular first sync signal 161 (e.g., a VSYNC signal) is received by frame timing circuit 121, and counter 127 is at a non-zero state, then controller 123 may (in some instances) send reset signal 102 to counter 127 to reset counter 127. This use of reset signal 102 may help mitigate an error made by frame timing circuit 121. For example, processor 111 may output an image with a pixel resolution of 600 by 400 to frame timing circuit 121, and frame timing circuit 121 may output an image with a pixel resolution of 1200×200 to display 131. If frame timing circuit 121 receives a particular first sync signal 161 (e.g., a VSYNC signal), then counter 127 may transition from its non-zero state to zero even if counter 127 is not at its natural transition point (e.g., counter 127 normally switches back to zero after receiving 1199 pixels, but a VSYNC signal is received by frame timing circuit 121 after frame timing circuit 121 received 1195 pixels, so counter 127 is reset to zero). This allows counter 127 to be properly reset despite an error occurring in frame timing circuit 121. However, it is worth noting that in some examples counter 127 may not count linearly and be reset to a non-zero base value.
Although the examples depicted in
The above description of illustrated examples of the invention, including what is described in the Abstract, is not intended to be exhaustive or to limit the invention to the precise forms disclosed. While specific examples of the invention are described herein for illustrative purposes, various modifications are possible within the scope of the invention, as those skilled in the relevant art will recognize.
These modifications can be made to the invention in light of the above detailed description. The terms used in the following claims should not be construed to limit the invention to the specific examples disclosed in the specification. Rather, the scope of the invention is to be determined entirely by the following claims, which are to be construed in accordance with established doctrines of claim interpretation.