Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4)

Side by Side Diff: third_party/WebKit/Source/core/layout/LayoutTableCell.h

Issue 2430313004: Paint collapsed borders of a table as one display item (Closed)
Patch Set: Rebaseline on mac and win Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 1997 Martin Jones (mjones@kde.org) 2 * Copyright (C) 1997 Martin Jones (mjones@kde.org)
3 * (C) 1997 Torben Weis (weis@kde.org) 3 * (C) 1997 Torben Weis (weis@kde.org)
4 * (C) 1998 Waldo Bastian (bastian@kde.org) 4 * (C) 1998 Waldo Bastian (bastian@kde.org)
5 * (C) 1999 Lars Knoll (knoll@kde.org) 5 * (C) 1999 Lars Knoll (knoll@kde.org)
6 * (C) 1999 Antti Koivisto (koivisto@kde.org) 6 * (C) 1999 Antti Koivisto (koivisto@kde.org)
7 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2009, 2013 Apple Inc. 7 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2009, 2013 Apple Inc.
8 * All rights reserved. 8 * All rights reserved.
9 * 9 *
10 * This library is free software; you can redistribute it and/or 10 * This library is free software; you can redistribute it and/or
(...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after
178 178
179 int borderLeft() const override; 179 int borderLeft() const override;
180 int borderRight() const override; 180 int borderRight() const override;
181 int borderTop() const override; 181 int borderTop() const override;
182 int borderBottom() const override; 182 int borderBottom() const override;
183 int borderStart() const override; 183 int borderStart() const override;
184 int borderEnd() const override; 184 int borderEnd() const override;
185 int borderBefore() const override; 185 int borderBefore() const override;
186 int borderAfter() const override; 186 int borderAfter() const override;
187 187
188 void collectBorderValues(LayoutTable::CollapsedBorderValues&); 188 // Returns true if any collapsed borders related to this cell changed.
189 static void sortBorderValues(LayoutTable::CollapsedBorderValues&); 189 bool collectBorderValues(Vector<CollapsedBorderValue>&);
190 static void sortBorderValues(Vector<CollapsedBorderValue>&);
190 191
191 void layout() override; 192 void layout() override;
192 193
193 void paint(const PaintInfo&, const LayoutPoint&) const override; 194 void paint(const PaintInfo&, const LayoutPoint&) const override;
194 195
195 int cellBaselinePosition() const; 196 int cellBaselinePosition() const;
196 bool isBaselineAligned() const { 197 bool isBaselineAligned() const {
197 EVerticalAlign va = style()->verticalAlign(); 198 EVerticalAlign va = style()->verticalAlign();
198 return va == VerticalAlignBaseline || va == VerticalAlignTextBottom || 199 return va == VerticalAlignBaseline || va == VerticalAlignTextBottom ||
199 va == VerticalAlignTextTop || va == VerticalAlignSuper || 200 va == VerticalAlignTextTop || va == VerticalAlignSuper ||
(...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after
279 280
280 #if ENABLE(ASSERT) 281 #if ENABLE(ASSERT)
281 bool isFirstOrLastCellInRow() const { 282 bool isFirstOrLastCellInRow() const {
282 return !table()->cellAfter(this) || !table()->cellBefore(this); 283 return !table()->cellAfter(this) || !table()->cellBefore(this);
283 } 284 }
284 #endif 285 #endif
285 286
286 const char* name() const override { return "LayoutTableCell"; } 287 const char* name() const override { return "LayoutTableCell"; }
287 288
288 bool backgroundIsKnownToBeOpaqueInRect(const LayoutRect&) const override; 289 bool backgroundIsKnownToBeOpaqueInRect(const LayoutRect&) const override;
289 void invalidateDisplayItemClients(PaintInvalidationReason) const override;
290 290
291 // TODO(wkorman): Consider renaming to more clearly differentiate from 291 struct CollapsedBorderValues {
292 // CollapsedBorderValue. 292 CollapsedBorderValue startBorder;
293 class CollapsedBorderValues : public DisplayItemClient { 293 CollapsedBorderValue endBorder;
294 public: 294 CollapsedBorderValue beforeBorder;
295 CollapsedBorderValues(const LayoutTable&, 295 CollapsedBorderValue afterBorder;
296 const CollapsedBorderValue& startBorder,
297 const CollapsedBorderValue& endBorder,
298 const CollapsedBorderValue& beforeBorder,
299 const CollapsedBorderValue& afterBorder);
300
301 const CollapsedBorderValue& startBorder() const { return m_startBorder; }
302 const CollapsedBorderValue& endBorder() const { return m_endBorder; }
303 const CollapsedBorderValue& beforeBorder() const { return m_beforeBorder; }
304 const CollapsedBorderValue& afterBorder() const { return m_afterBorder; }
305
306 void setCollapsedBorderValues(const CollapsedBorderValues& other);
307
308 // DisplayItemClient methods.
309 String debugName() const;
310 LayoutRect visualRect() const;
311
312 private:
313 const LayoutTable& m_layoutTable;
314 CollapsedBorderValue m_startBorder;
315 CollapsedBorderValue m_endBorder;
316 CollapsedBorderValue m_beforeBorder;
317 CollapsedBorderValue m_afterBorder;
318 }; 296 };
319 297
320 bool usesTableAsAdditionalDisplayItemClient() const;
321 const CollapsedBorderValues* collapsedBorderValues() const { 298 const CollapsedBorderValues* collapsedBorderValues() const {
322 return m_collapsedBorderValues.get(); 299 return m_collapsedBorderValues.get();
323 } 300 }
324 301
325 LayoutRect debugRect() const override; 302 LayoutRect debugRect() const override;
326 303
327 void adjustChildDebugRect(LayoutRect&) const override; 304 void adjustChildDebugRect(LayoutRect&) const override;
328 305
329 // A table cell's location is relative to its containing section. 306 // A table cell's location is relative to its containing section.
330 LayoutBox* locationContainer() const override { return section(); } 307 LayoutBox* locationContainer() const override { return section(); }
331 308
309 LayoutRect localVisualRect() const override;
310
332 protected: 311 protected:
333 void styleDidChange(StyleDifference, const ComputedStyle* oldStyle) override; 312 void styleDidChange(StyleDifference, const ComputedStyle* oldStyle) override;
334 void computePreferredLogicalWidths() override; 313 void computePreferredLogicalWidths() override;
335 314
336 void addLayerHitTestRects(LayerHitTestRects&, 315 void addLayerHitTestRects(LayerHitTestRects&,
337 const PaintLayer* currentCompositedLayer, 316 const PaintLayer* currentCompositedLayer,
338 const LayoutPoint& layerOffset, 317 const LayoutPoint& layerOffset,
339 const LayoutRect& containerRect) const override; 318 const LayoutRect& containerRect) const override;
340 319
341 private: 320 private:
342 bool isOfType(LayoutObjectType type) const override { 321 bool isOfType(LayoutObjectType type) const override {
343 return type == LayoutObjectTableCell || LayoutBlockFlow::isOfType(type); 322 return type == LayoutObjectTableCell || LayoutBlockFlow::isOfType(type);
344 } 323 }
345 324
346 void willBeRemovedFromTree() override; 325 void willBeRemovedFromTree() override;
347 326
348 void updateLogicalWidth() override; 327 void updateLogicalWidth() override;
349 328
350 void paintBoxDecorationBackground(const PaintInfo&, 329 void paintBoxDecorationBackground(const PaintInfo&,
351 const LayoutPoint&) const override; 330 const LayoutPoint&) const override;
352 void paintMask(const PaintInfo&, const LayoutPoint&) const override; 331 void paintMask(const PaintInfo&, const LayoutPoint&) const override;
353 332
354 LayoutSize offsetFromContainer(const LayoutObject*) const override; 333 LayoutSize offsetFromContainer(const LayoutObject*) const override;
355 LayoutRect localVisualRect() const override;
356 334
357 int borderHalfLeft(bool outer) const; 335 int borderHalfLeft(bool outer) const;
358 int borderHalfRight(bool outer) const; 336 int borderHalfRight(bool outer) const;
359 int borderHalfTop(bool outer) const; 337 int borderHalfTop(bool outer) const;
360 int borderHalfBottom(bool outer) const; 338 int borderHalfBottom(bool outer) const;
361 339
362 int borderHalfStart(bool outer) const; 340 int borderHalfStart(bool outer) const;
363 int borderHalfEnd(bool outer) const; 341 int borderHalfEnd(bool outer) const;
364 int borderHalfBefore(bool outer) const; 342 int borderHalfBefore(bool outer) const;
365 int borderHalfAfter(bool outer) const; 343 int borderHalfAfter(bool outer) const;
(...skipping 17 matching lines...) Expand all
383 // column, column group). 361 // column, column group).
384 // TODO(jchaffraix): It should be easier to compute all the borders in 362 // TODO(jchaffraix): It should be easier to compute all the borders in
385 // physical coordinates. However this is not the design of the current code. 363 // physical coordinates. However this is not the design of the current code.
386 // 364 //
387 // Blink's support for mixed directionality is currently partial. We only 365 // Blink's support for mixed directionality is currently partial. We only
388 // support the directionality up to |styleForCellFlow|. See comment on the 366 // support the directionality up to |styleForCellFlow|. See comment on the
389 // function above for more details. 367 // function above for more details.
390 // See also https://code.google.com/p/chromium/issues/detail?id=128227 for 368 // See also https://code.google.com/p/chromium/issues/detail?id=128227 for
391 // some history. 369 // some history.
392 // 370 //
393 // Those functions are called when the cache (m_collapsedBorders) is 371 // Those functions are called before paint invalidation if the collapsed
394 // invalidated on LayoutTable. 372 // borders cache is invalidated on LayoutTable.
395 CollapsedBorderValue computeCollapsedStartBorder( 373 CollapsedBorderValue computeCollapsedStartBorder(
396 IncludeBorderColorOrNot = IncludeBorderColor) const; 374 IncludeBorderColorOrNot = IncludeBorderColor) const;
397 CollapsedBorderValue computeCollapsedEndBorder( 375 CollapsedBorderValue computeCollapsedEndBorder(
398 IncludeBorderColorOrNot = IncludeBorderColor) const; 376 IncludeBorderColorOrNot = IncludeBorderColor) const;
399 CollapsedBorderValue computeCollapsedBeforeBorder( 377 CollapsedBorderValue computeCollapsedBeforeBorder(
400 IncludeBorderColorOrNot = IncludeBorderColor) const; 378 IncludeBorderColorOrNot = IncludeBorderColor) const;
401 CollapsedBorderValue computeCollapsedAfterBorder( 379 CollapsedBorderValue computeCollapsedAfterBorder(
402 IncludeBorderColorOrNot = IncludeBorderColor) const; 380 IncludeBorderColorOrNot = IncludeBorderColor) const;
403 381
404 Length logicalWidthFromColumns(LayoutTableCol* firstColForThisCell, 382 Length logicalWidthFromColumns(LayoutTableCol* firstColForThisCell,
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
444 return toLayoutTableCell(firstChild()); 422 return toLayoutTableCell(firstChild());
445 } 423 }
446 424
447 inline LayoutTableCell* LayoutTableRow::lastCell() const { 425 inline LayoutTableCell* LayoutTableRow::lastCell() const {
448 return toLayoutTableCell(lastChild()); 426 return toLayoutTableCell(lastChild());
449 } 427 }
450 428
451 } // namespace blink 429 } // namespace blink
452 430
453 #endif // LayoutTableCell_h 431 #endif // LayoutTableCell_h
OLDNEW
« no previous file with comments | « third_party/WebKit/Source/core/layout/LayoutTable.cpp ('k') | third_party/WebKit/Source/core/layout/LayoutTableCell.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698