mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-18 08:07:56 +01:00

We currently use raw jobject in our code mixed with sporadic ScopedLocalRefFrame. This CL moves every jobject into a scoped object, either local, global, or a parameter. Also, this CL uses the JNI generation script to generate declaration stubs for the Java->C++ functions so that it no longer becomes possible to mistype them without getting compilation errors. TBR=brandt@webrtc.org Bug: webrtc:8278,webrtc:6969 Change-Id: Ic7bac74a89c11180177d65041086d7db1cdfb516 Reviewed-on: https://webrtc-review.googlesource.com/34655 Commit-Queue: Magnus Jedvert <magjed@webrtc.org> Reviewed-by: Sami Kalliomäki <sakal@webrtc.org> Cr-Commit-Position: refs/heads/master@{#21387}
82 lines
2.4 KiB
Java
82 lines
2.4 KiB
Java
/*
|
|
* Copyright 2016 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
package org.webrtc;
|
|
|
|
import java.util.HashMap;
|
|
import java.util.Map;
|
|
|
|
// Java-side of androidmetrics.cc
|
|
//
|
|
// Rtc histograms can be queried through the API, getAndReset().
|
|
// The returned map holds the name of a histogram and its samples.
|
|
//
|
|
// Example of |map| with one histogram:
|
|
// |name|: "WebRTC.Video.InputFramesPerSecond"
|
|
// |min|: 1
|
|
// |max|: 100
|
|
// |bucketCount|: 50
|
|
// |samples|: [30]:1
|
|
//
|
|
// Most histograms are not updated frequently (e.g. most video metrics are an
|
|
// average over the call and recorded when a stream is removed).
|
|
// The metrics can for example be retrieved when a peer connection is closed.
|
|
@JNINamespace("webrtc::jni")
|
|
public class Metrics {
|
|
private static final String TAG = "Metrics";
|
|
|
|
public final Map<String, HistogramInfo> map =
|
|
new HashMap<String, HistogramInfo>(); // <name, HistogramInfo>
|
|
|
|
@CalledByNative
|
|
Metrics() {}
|
|
|
|
/**
|
|
* Class holding histogram information.
|
|
*/
|
|
public static class HistogramInfo {
|
|
public final int min;
|
|
public final int max;
|
|
public final int bucketCount;
|
|
public final Map<Integer, Integer> samples =
|
|
new HashMap<Integer, Integer>(); // <value, # of events>
|
|
|
|
@CalledByNative("HistogramInfo")
|
|
public HistogramInfo(int min, int max, int bucketCount) {
|
|
this.min = min;
|
|
this.max = max;
|
|
this.bucketCount = bucketCount;
|
|
}
|
|
|
|
@CalledByNative("HistogramInfo")
|
|
public void addSample(int value, int numEvents) {
|
|
samples.put(value, numEvents);
|
|
}
|
|
}
|
|
|
|
@CalledByNative
|
|
private void add(String name, HistogramInfo info) {
|
|
map.put(name, info);
|
|
}
|
|
|
|
// Enables gathering of metrics (which can be fetched with getAndReset()).
|
|
// Must be called before PeerConnectionFactory is created.
|
|
public static void enable() {
|
|
nativeEnable();
|
|
}
|
|
|
|
// Gets and clears native histograms.
|
|
public static Metrics getAndReset() {
|
|
return nativeGetAndReset();
|
|
}
|
|
|
|
private static native void nativeEnable();
|
|
private static native Metrics nativeGetAndReset();
|
|
}
|