summaryrefslogtreecommitdiffstats
path: root/remoting/client/rectangle_update_decoder.cc
diff options
context:
space:
mode:
authorsergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-09-25 22:16:21 +0000
committersergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-09-25 22:16:21 +0000
commite59d6594e14b9a697098cc517f7218941e2787ff (patch)
treee04cc296501d095e24acfb5357c5af5bacebca82 /remoting/client/rectangle_update_decoder.cc
parent1f291cd57a56e70369dc2e47e3d4be6102254102 (diff)
downloadchromium_src-e59d6594e14b9a697098cc517f7218941e2787ff.zip
chromium_src-e59d6594e14b9a697098cc517f7218941e2787ff.tar.gz
chromium_src-e59d6594e14b9a697098cc517f7218941e2787ff.tar.bz2
Remove dependency on Skia from chromoting client.
Now DesktopRegion, DesktopRect and DesktopSize are used instead of corresponding skia types. R=alexeypa@chromium.org TBR=reed@google.com (for _moved_ skia dependency) Committed: https://src.chromium.org/viewvc/chrome?view=rev&revision=224101 Review URL: https://codereview.chromium.org/23440046 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@225265 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'remoting/client/rectangle_update_decoder.cc')
-rw-r--r--remoting/client/rectangle_update_decoder.cc46
1 files changed, 22 insertions, 24 deletions
diff --git a/remoting/client/rectangle_update_decoder.cc b/remoting/client/rectangle_update_decoder.cc
index 3f21a99..af123e8 100644
--- a/remoting/client/rectangle_update_decoder.cc
+++ b/remoting/client/rectangle_update_decoder.cc
@@ -31,10 +31,6 @@ RectangleUpdateDecoder::RectangleUpdateDecoder(
: main_task_runner_(main_task_runner),
decode_task_runner_(decode_task_runner),
consumer_(consumer),
- source_size_(SkISize::Make(0, 0)),
- source_dpi_(SkIPoint::Make(0, 0)),
- view_size_(SkISize::Make(0, 0)),
- clip_area_(SkIRect::MakeEmpty()),
paint_scheduled_(false),
latest_sequence_number_(0) {
}
@@ -66,25 +62,25 @@ void RectangleUpdateDecoder::DecodePacket(scoped_ptr<VideoPacket> packet,
// If the packet includes screen size or DPI information, store them.
if (packet->format().has_screen_width() &&
packet->format().has_screen_height()) {
- SkISize source_size = SkISize::Make(packet->format().screen_width(),
- packet->format().screen_height());
- if (source_size_ != source_size) {
+ webrtc::DesktopSize source_size(packet->format().screen_width(),
+ packet->format().screen_height());
+ if (!source_size_.equals(source_size)) {
source_size_ = source_size;
decoder_needs_reset = true;
notify_size_or_dpi_change = true;
}
}
if (packet->format().has_x_dpi() && packet->format().has_y_dpi()) {
- SkIPoint source_dpi(SkIPoint::Make(packet->format().x_dpi(),
- packet->format().y_dpi()));
- if (source_dpi != source_dpi_) {
+ webrtc::DesktopVector source_dpi(packet->format().x_dpi(),
+ packet->format().y_dpi());
+ if (!source_dpi.equals(source_dpi_)) {
source_dpi_ = source_dpi;
notify_size_or_dpi_change = true;
}
}
// If we've never seen a screen size, ignore the packet.
- if (source_size_.isZero())
+ if (source_size_.is_empty())
return;
if (decoder_needs_reset)
@@ -112,23 +108,23 @@ void RectangleUpdateDecoder::DoPaint() {
paint_scheduled_ = false;
// If the view size is empty or we have no output buffers ready, return.
- if (buffers_.empty() || view_size_.isEmpty())
+ if (buffers_.empty() || view_size_.is_empty())
return;
// If no Decoder is initialized, or the host dimensions are empty, return.
- if (!decoder_.get() || source_size_.isEmpty())
+ if (!decoder_.get() || source_size_.is_empty())
return;
// Draw the invalidated region to the buffer.
webrtc::DesktopFrame* buffer = buffers_.front();
- SkRegion output_region;
+ webrtc::DesktopRegion output_region;
decoder_->RenderFrame(view_size_, clip_area_,
buffer->data(),
buffer->stride(),
&output_region);
// Notify the consumer that painting is done.
- if (!output_region.isEmpty()) {
+ if (!output_region.is_empty()) {
buffers_.pop_front();
consumer_->ApplyBuffer(view_size_, clip_area_, buffer, output_region);
}
@@ -166,7 +162,8 @@ void RectangleUpdateDecoder::DrawBuffer(webrtc::DesktopFrame* buffer) {
SchedulePaint();
}
-void RectangleUpdateDecoder::InvalidateRegion(const SkRegion& region) {
+void RectangleUpdateDecoder::InvalidateRegion(
+ const webrtc::DesktopRegion& region) {
if (!decode_task_runner_->BelongsToCurrentThread()) {
decode_task_runner_->PostTask(
FROM_HERE, base::Bind(&RectangleUpdateDecoder::InvalidateRegion,
@@ -180,8 +177,9 @@ void RectangleUpdateDecoder::InvalidateRegion(const SkRegion& region) {
}
}
-void RectangleUpdateDecoder::SetOutputSizeAndClip(const SkISize& view_size,
- const SkIRect& clip_area) {
+void RectangleUpdateDecoder::SetOutputSizeAndClip(
+ const webrtc::DesktopSize& view_size,
+ const webrtc::DesktopRect& clip_area) {
if (!decode_task_runner_->BelongsToCurrentThread()) {
decode_task_runner_->PostTask(
FROM_HERE, base::Bind(&RectangleUpdateDecoder::SetOutputSizeAndClip,
@@ -190,14 +188,14 @@ void RectangleUpdateDecoder::SetOutputSizeAndClip(const SkISize& view_size,
}
// The whole frame needs to be repainted if the scaling factor has changed.
- if (view_size_ != view_size && decoder_.get()) {
- SkRegion region;
- region.op(SkIRect::MakeSize(view_size), SkRegion::kUnion_Op);
+ if (!view_size_.equals(view_size) && decoder_.get()) {
+ webrtc::DesktopRegion region;
+ region.AddRect(webrtc::DesktopRect::MakeSize(view_size));
decoder_->Invalidate(view_size, region);
}
- if (view_size_ != view_size ||
- clip_area_ != clip_area) {
+ if (!view_size_.equals(view_size) ||
+ !clip_area_.equals(clip_area)) {
view_size_ = view_size;
clip_area_ = clip_area;
@@ -218,7 +216,7 @@ void RectangleUpdateDecoder::SetOutputSizeAndClip(const SkISize& view_size,
}
}
-const SkRegion* RectangleUpdateDecoder::GetBufferShape() {
+const webrtc::DesktopRegion* RectangleUpdateDecoder::GetBufferShape() {
return decoder_->GetImageShape();
}