| OLD | NEW | 
|---|
| 1 /* | 1 /* | 
| 2  * libjingle | 2  *  Copyright 2010 The WebRTC Project Authors. All rights reserved. | 
| 3  * Copyright 2010 Google Inc. |  | 
| 4  * | 3  * | 
| 5  * Redistribution and use in source and binary forms, with or without | 4  *  Use of this source code is governed by a BSD-style license | 
| 6  * modification, are permitted provided that the following conditions are met: | 5  *  that can be found in the LICENSE file in the root of the source | 
| 7  * | 6  *  tree. An additional intellectual property rights grant can be found | 
| 8  *  1. Redistributions of source code must retain the above copyright notice, | 7  *  in the file PATENTS.  All contributing project authors may | 
| 9  *     this list of conditions and the following disclaimer. | 8  *  be found in the AUTHORS file in the root of the source tree. | 
| 10  *  2. Redistributions in binary form must reproduce the above copyright notice, |  | 
| 11  *     this list of conditions and the following disclaimer in the documentation |  | 
| 12  *     and/or other materials provided with the distribution. |  | 
| 13  *  3. The name of the author may not be used to endorse or promote products |  | 
| 14  *     derived from this software without specific prior written permission. |  | 
| 15  * |  | 
| 16  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED |  | 
| 17  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |  | 
| 18  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO |  | 
| 19  * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |  | 
| 20  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |  | 
| 21  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; |  | 
| 22  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, |  | 
| 23  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR |  | 
| 24  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF |  | 
| 25  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | 
| 26  */ | 9  */ | 
| 27 | 10 | 
| 28 #include "talk/media/base/videocommon.h" | 11 #include "webrtc/media/base/videocommon.h" | 
| 29 | 12 | 
| 30 #include <limits.h>  // For INT_MAX | 13 #include <limits.h>  // For INT_MAX | 
| 31 #include <math.h> | 14 #include <math.h> | 
| 32 #include <sstream> | 15 #include <sstream> | 
| 33 | 16 | 
| 34 #include "webrtc/base/arraysize.h" | 17 #include "webrtc/base/arraysize.h" | 
| 35 #include "webrtc/base/common.h" | 18 #include "webrtc/base/common.h" | 
| 36 | 19 | 
| 37 namespace cricket { | 20 namespace cricket { | 
| 38 | 21 | 
| (...skipping 13 matching lines...) Expand all  Loading... | 
| 52   {FOURCC_JPEG, FOURCC_MJPG},  // Note: JPEG has DHT while MJPG does not. | 35   {FOURCC_JPEG, FOURCC_MJPG},  // Note: JPEG has DHT while MJPG does not. | 
| 53   {FOURCC_DMB1, FOURCC_MJPG}, | 36   {FOURCC_DMB1, FOURCC_MJPG}, | 
| 54   {FOURCC_BA81, FOURCC_BGGR}, | 37   {FOURCC_BA81, FOURCC_BGGR}, | 
| 55   {FOURCC_RGB3, FOURCC_RAW}, | 38   {FOURCC_RGB3, FOURCC_RAW}, | 
| 56   {FOURCC_BGR3, FOURCC_24BG}, | 39   {FOURCC_BGR3, FOURCC_24BG}, | 
| 57   {FOURCC_CM32, FOURCC_BGRA}, | 40   {FOURCC_CM32, FOURCC_BGRA}, | 
| 58   {FOURCC_CM24, FOURCC_RAW}, | 41   {FOURCC_CM24, FOURCC_RAW}, | 
| 59 }; | 42 }; | 
| 60 | 43 | 
| 61 uint32_t CanonicalFourCC(uint32_t fourcc) { | 44 uint32_t CanonicalFourCC(uint32_t fourcc) { | 
| 62   for (int i = 0; i < arraysize(kFourCCAliases); ++i) { | 45   for (uint32_t i = 0; i < arraysize(kFourCCAliases); ++i) { | 
| 63     if (kFourCCAliases[i].alias == fourcc) { | 46     if (kFourCCAliases[i].alias == fourcc) { | 
| 64       return kFourCCAliases[i].canonical; | 47       return kFourCCAliases[i].canonical; | 
| 65     } | 48     } | 
| 66   } | 49   } | 
| 67   // Not an alias, so return it as-is. | 50   // Not an alias, so return it as-is. | 
| 68   return fourcc; | 51   return fourcc; | 
| 69 } | 52 } | 
| 70 | 53 | 
| 71 static float kScaleFactors[] = { | 54 static float kScaleFactors[] = { | 
| 72   1.f / 1.f,  // Full size. | 55   1.f / 1.f,  // Full size. | 
| (...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 235     } | 218     } | 
| 236   } | 219   } | 
| 237 | 220 | 
| 238   std::ostringstream ss; | 221   std::ostringstream ss; | 
| 239   ss << fourcc_name << width << "x" << height << "x" | 222   ss << fourcc_name << width << "x" << height << "x" | 
| 240      << IntervalToFpsFloat(interval); | 223      << IntervalToFpsFloat(interval); | 
| 241   return ss.str(); | 224   return ss.str(); | 
| 242 } | 225 } | 
| 243 | 226 | 
| 244 }  // namespace cricket | 227 }  // namespace cricket | 
| OLD | NEW | 
|---|