This source file includes following definitions.
- create
- orientation
- addChildren
- getAttribute
- elementAccessibilityHitTest
- setValue
- element
- create
- elementRect
- computeAccessibilityIsIgnored
#include "config.h"
#include "core/accessibility/AXSlider.h"
#include "core/accessibility/AXObjectCache.h"
#include "core/dom/shadow/ShadowRoot.h"
#include "core/html/HTMLInputElement.h"
#include "core/html/shadow/ShadowElementNames.h"
#include "core/rendering/RenderObject.h"
namespace WebCore {
using namespace HTMLNames;
AXSlider::AXSlider(RenderObject* renderer)
: AXRenderObject(renderer)
{
}
PassRefPtr<AXSlider> AXSlider::create(RenderObject* renderer)
{
return adoptRef(new AXSlider(renderer));
}
AccessibilityOrientation AXSlider::orientation() const
{
if (!m_renderer)
return AccessibilityOrientationHorizontal;
RenderStyle* style = m_renderer->style();
if (!style)
return AccessibilityOrientationHorizontal;
ControlPart styleAppearance = style->appearance();
switch (styleAppearance) {
case SliderThumbHorizontalPart:
case SliderHorizontalPart:
case MediaSliderPart:
case MediaFullScreenVolumeSliderPart:
return AccessibilityOrientationHorizontal;
case SliderThumbVerticalPart:
case SliderVerticalPart:
case MediaVolumeSliderPart:
return AccessibilityOrientationVertical;
default:
return AccessibilityOrientationHorizontal;
}
}
void AXSlider::addChildren()
{
ASSERT(!m_haveChildren);
m_haveChildren = true;
AXObjectCache* cache = m_renderer->document().axObjectCache();
AXSliderThumb* thumb = static_cast<AXSliderThumb*>(cache->getOrCreate(SliderThumbRole));
thumb->setParent(this);
if (thumb->accessibilityIsIgnored())
cache->remove(thumb->axObjectID());
else
m_children.append(thumb);
}
const AtomicString& AXSlider::getAttribute(const QualifiedName& attribute) const
{
return element()->getAttribute(attribute);
}
AXObject* AXSlider::elementAccessibilityHitTest(const IntPoint& point) const
{
if (m_children.size()) {
ASSERT(m_children.size() == 1);
if (m_children[0]->elementRect().contains(point))
return m_children[0].get();
}
return axObjectCache()->getOrCreate(m_renderer);
}
void AXSlider::setValue(const String& value)
{
HTMLInputElement* input = element();
if (input->value() == value)
return;
input->setValue(value);
input->dispatchFormControlChangeEvent();
}
HTMLInputElement* AXSlider::element() const
{
return toHTMLInputElement(m_renderer->node());
}
AXSliderThumb::AXSliderThumb()
{
}
PassRefPtr<AXSliderThumb> AXSliderThumb::create()
{
return adoptRef(new AXSliderThumb());
}
LayoutRect AXSliderThumb::elementRect() const
{
if (!m_parent)
return LayoutRect();
RenderObject* sliderRenderer = m_parent->renderer();
if (!sliderRenderer || !sliderRenderer->isSlider())
return LayoutRect();
return toElement(sliderRenderer->node())->userAgentShadowRoot()->getElementById(ShadowElementNames::sliderThumb())->boundingBox();
}
bool AXSliderThumb::computeAccessibilityIsIgnored() const
{
return accessibilityIsIgnoredByDefault();
}
}