| /** |
| * This file is part of the DOM implementation for KDE. |
| * |
| * Copyright (C) 2001 Peter Kelly (pmk@post.com) |
| * Copyright (C) 2001 Tobias Anton (anton@stud.fbi.fh-darmstadt.de) |
| * Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com) |
| * Copyright (C) 2003, 2005, 2006 Apple Computer, Inc. |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Library General Public |
| * License as published by the Free Software Foundation; either |
| * version 2 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Library General Public License for more details. |
| * |
| * You should have received a copy of the GNU Library General Public License |
| * along with this library; see the file COPYING.LIB. If not, write to |
| * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
| * Boston, MA 02110-1301, USA. |
| */ |
| |
| #include "config.h" |
| #include "MouseEvent.h" |
| |
| #include "EventNames.h" |
| |
| namespace WebCore { |
| |
| using namespace EventNames; |
| |
| MouseEvent::MouseEvent() |
| : m_button(0) |
| , m_buttonDown(false) |
| { |
| } |
| |
| MouseEvent::MouseEvent(const AtomicString& eventType, bool canBubble, bool cancelable, AbstractView* view, |
| int detail, int screenX, int screenY, int pageX, int pageY, |
| bool ctrlKey, bool altKey, bool shiftKey, bool metaKey, |
| unsigned short button, EventTargetNode* relatedTarget, |
| Clipboard* clipboard, bool isSimulated) |
| : MouseRelatedEvent(eventType, canBubble, cancelable, view, detail, screenX, screenY, |
| pageX, pageY, ctrlKey, altKey, shiftKey, metaKey, isSimulated) |
| , m_button(button == (unsigned short)-1 ? 0 : button) |
| , m_buttonDown(button != (unsigned short)-1) |
| , m_relatedTarget(relatedTarget) |
| , m_clipboard(clipboard) |
| { |
| } |
| |
| MouseEvent::~MouseEvent() |
| { |
| } |
| |
| void MouseEvent::initMouseEvent(const AtomicString& type, bool canBubble, bool cancelable, AbstractView* view, |
| int detail, int screenX, int screenY, int clientX, int clientY, |
| bool ctrlKey, bool altKey, bool shiftKey, bool metaKey, |
| unsigned short button, EventTargetNode* relatedTarget) |
| { |
| if (dispatched()) |
| return; |
| |
| initUIEvent(type, canBubble, cancelable, view, detail); |
| |
| m_screenX = screenX; |
| m_screenY = screenY; |
| m_ctrlKey = ctrlKey; |
| m_altKey = altKey; |
| m_shiftKey = shiftKey; |
| m_metaKey = metaKey; |
| m_button = button == (unsigned short)-1 ? 0 : button; |
| m_buttonDown = button != (unsigned short)-1; |
| m_relatedTarget = relatedTarget; |
| |
| initCoordinates(clientX, clientY); |
| |
| // FIXME: m_isSimulated is not set to false here. |
| // FIXME: m_clipboard is not set to 0 here. |
| } |
| |
| bool MouseEvent::isMouseEvent() const |
| { |
| return true; |
| } |
| |
| bool MouseEvent::isDragEvent() const |
| { |
| const AtomicString& t = type(); |
| return t == dragenterEvent || t == dragoverEvent || t == dragleaveEvent || t == dropEvent |
| || t == dragstartEvent|| t == dragEvent || t == dragendEvent; |
| } |
| |
| int MouseEvent::which() const |
| { |
| // For the DOM, the return values for left, middle and right mouse buttons are 0, 1, 2, respectively. |
| // For the Netscape "which" property, the return values for left, middle and right mouse buttons are 1, 2, 3, respectively. |
| // So we must add 1. |
| return m_button + 1; |
| } |
| |
| Node* MouseEvent::toElement() const |
| { |
| // MSIE extension - "the object toward which the user is moving the mouse pointer" |
| if (type() == mouseoutEvent) |
| return relatedTarget(); |
| |
| return target() ? target()->toNode() : 0; |
| } |
| |
| Node* MouseEvent::fromElement() const |
| { |
| // MSIE extension - "object from which activation or the mouse pointer is exiting during the event" (huh?) |
| if (type() != mouseoutEvent) |
| return relatedTarget(); |
| |
| return target() ? target()->toNode() : 0; |
| } |
| |
| } // namespace WebCore |