| OLD | NEW |
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "remoting/host/capturer_fake_ascii.h" | 5 #include "remoting/host/capturer_fake_ascii.h" |
| 6 | 6 |
| 7 #include "gfx/rect.h" | 7 #include "gfx/rect.h" |
| 8 | 8 |
| 9 namespace remoting { | 9 namespace remoting { |
| 10 | 10 |
| 11 static const int kWidth = 32; | 11 static const int kWidth = 32; |
| 12 static const int kHeight = 20; | 12 static const int kHeight = 20; |
| 13 static const int kBytesPerPixel = 1; | 13 static const int kBytesPerPixel = 1; |
| 14 | 14 |
| 15 CapturerFakeAscii::CapturerFakeAscii() { | 15 CapturerFakeAscii::CapturerFakeAscii() { |
| 16 } | 16 } |
| 17 | 17 |
| 18 CapturerFakeAscii::~CapturerFakeAscii() { | 18 CapturerFakeAscii::~CapturerFakeAscii() { |
| 19 } | 19 } |
| 20 | 20 |
| 21 void CapturerFakeAscii::CaptureRects(const RectVector& rects, | |
| 22 CaptureCompletedCallback* callback) { | |
| 23 GenerateImage(); | |
| 24 DataPlanes planes; | |
| 25 planes.data[0] = buffers_[current_buffer_].get(); | |
| 26 planes.strides[0] = bytes_per_row_; | |
| 27 scoped_refptr<CaptureData> capture_data(new CaptureData(planes, | |
| 28 width_, | |
| 29 height_, | |
| 30 pixel_format_)); | |
| 31 FinishCapture(capture_data, callback); | |
| 32 } | |
| 33 | |
| 34 void CapturerFakeAscii::ScreenConfigurationChanged() { | 21 void CapturerFakeAscii::ScreenConfigurationChanged() { |
| 35 width_ = kWidth; | 22 width_ = kWidth; |
| 36 height_ = kHeight; | 23 height_ = kHeight; |
| 37 pixel_format_ = PixelFormatAscii; | 24 pixel_format_ = PixelFormatAscii; |
| 38 bytes_per_row_ = width_ * kBytesPerPixel; | 25 bytes_per_row_ = width_ * kBytesPerPixel; |
| 39 | 26 |
| 40 // Create memory for the buffers. | 27 // Create memory for the buffers. |
| 41 int buffer_size = height_ * bytes_per_row_; | 28 int buffer_size = height_ * bytes_per_row_; |
| 42 for (int i = 0; i < kNumBuffers; i++) { | 29 for (int i = 0; i < kNumBuffers; i++) { |
| 43 buffers_[i].reset(new uint8[buffer_size]); | 30 buffers_[i].reset(new uint8[buffer_size]); |
| 44 } | 31 } |
| 45 } | 32 } |
| 46 | 33 |
| 34 void CapturerFakeAscii::CalculateInvalidRects() { |
| 35 // Capture and invalidate the entire screen. |
| 36 // Performing the capture here is modelled on the Windows |
| 37 // GDI capturer. |
| 38 GenerateImage(); |
| 39 InvalidateFullScreen(); |
| 40 } |
| 41 |
| 42 void CapturerFakeAscii::CaptureRects(const InvalidRects& rects, |
| 43 CaptureCompletedCallback* callback) { |
| 44 DataPlanes planes; |
| 45 planes.data[0] = buffers_[current_buffer_].get(); |
| 46 planes.strides[0] = bytes_per_row_; |
| 47 scoped_refptr<CaptureData> capture_data(new CaptureData(planes, |
| 48 width_, |
| 49 height_, |
| 50 pixel_format_)); |
| 51 FinishCapture(capture_data, callback); |
| 52 } |
| 53 |
| 47 void CapturerFakeAscii::GenerateImage() { | 54 void CapturerFakeAscii::GenerateImage() { |
| 48 for (int y = 0; y < height_; ++y) { | 55 for (int y = 0; y < height_; ++y) { |
| 49 uint8* row = buffers_[current_buffer_].get() + bytes_per_row_ * y; | 56 uint8* row = buffers_[current_buffer_].get() + bytes_per_row_ * y; |
| 50 for (int x = 0; x < bytes_per_row_; ++x) { | 57 for (int x = 0; x < bytes_per_row_; ++x) { |
| 51 if (y == 0 || x == 0 || x == (width_ - 1) || y == (height_ - 1)) { | 58 if (y == 0 || x == 0 || x == (width_ - 1) || y == (height_ - 1)) { |
| 52 row[x] = '*'; | 59 row[x] = '*'; |
| 53 } else { | 60 } else { |
| 54 row[x] = ' '; | 61 row[x] = ' '; |
| 55 } | 62 } |
| 56 } | 63 } |
| 57 } | 64 } |
| 58 } | 65 } |
| 59 | 66 |
| 60 } // namespace remoting | 67 } // namespace remoting |
| OLD | NEW |