Files
react-native/ReactCommon/react/renderer/core/BatchedEventQueue.h
T
Samuel Susla 2669118fc8 Make event coalescing more aggressive
Summary:
Changelog: [internal]

Previous implementation of coalescing would only look at the last element in `eventQueue_` and if it was the same type and target, it would coalesce the two together. This was problem when user would scroll in UIScrollView, this triggers onTouchMove and onScroll events at high rates and prevents coalescing of them.

This changes changes the behaviour to search the `eventQueue_` backwards for an event of the same type and target. If one if found, it is moved into its place. If even of another type is found before for the same target, the event is pushed back onto the queue.

Reviewed By: JoshuaGross

Differential Revision: D24992941

fbshipit-source-id: fc1eae4ecd100af6202346674778b0634ed7a15b
2020-11-17 04:21:01 -08:00

42 lines
981 B
C++

/*
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#pragma once
#include <react/renderer/core/EventQueue.h>
namespace facebook {
namespace react {
/*
* Event Queue that dispatches event in batches synchronizing them with
* an Event Beat.
*/
class BatchedEventQueue final : public EventQueue {
public:
BatchedEventQueue(
EventPipe eventPipe,
StatePipe statePipe,
std::unique_ptr<EventBeat> eventBeat,
bool enableV2EventCoalescing);
void onEnqueue() const override;
/*
* Enqueues and (probably later) dispatches a given event.
* Deletes last RawEvent from the queue if it has the same type and target.
* Can be called on any thread.
*/
void enqueueUniqueEvent(const RawEvent &rawEvent) const;
private:
bool const enableV2EventCoalescing_;
};
} // namespace react
} // namespace facebook