當前位置: 首頁>>代碼示例>>Python>>正文


Python flask_socketio.emit方法代碼示例

本文整理匯總了Python中flask_socketio.emit方法的典型用法代碼示例。如果您正苦於以下問題:Python flask_socketio.emit方法的具體用法?Python flask_socketio.emit怎麽用?Python flask_socketio.emit使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在flask_socketio的用法示例。


在下文中一共展示了flask_socketio.emit方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: process_video

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def process_video(filepath):
    """
        Processes Video Submitted by User
    """
    global video_fps_rate

    width, height, fps_rate = convert_to_frames(filepath)  # convert the video to images
    ordered_files = sorted(os.listdir(frames_dir), key=lambda x: (int(re.sub(r'\D','',x)),x))

    # Convert all frames to base64 images and begin calling
    for index, frame in enumerate(ordered_files):
        with open(os.path.join(frames_dir, frame), 'rb') as image_file:
            encoded_string = base64.b64encode(image_file.read())
            base64_frames[index] = encoded_string.decode('utf-8')

    cleanup_video_frames()

    video_fps_rate[0] = fps_rate

    # Frames are ready - start sending them to for pooling
    # Let's emit a message indicating that we're about to start sending files
    socketio.emit('canvas_width_height', {'width': width, 'height': height}) 
開發者ID:Notabela,項目名稱:Lie_to_me,代碼行數:24,代碼來源:process.py

示例2: background_thread

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def background_thread(uid_with_size):
    uid, size = uid_with_size.split(';')
    r = redis.StrictRedis(oc.cfg['default']['redis'], 6379, db=0)
    r.set(uid+'size', size)
    pubsub = r.pubsub()
    pubsub.subscribe('l'+uid)
    count = 0
    for message in pubsub.listen():
        # Filter out events like Redis connections.
        if message['type'] != 'message':
            continue
        count += 1
        socketio.sleep(0.01)
        try:
            data = json.loads(message['data'].decode('utf8'))
            msg = uid + data['name'] + ': ' + data['levelname'] + ': ' + data['msg']
            socketio.emit('log_response', {'data': msg, 'count': count}, namespace='/omega_log')
        except:
            pass 
開發者ID:OmegaTrading,項目名稱:OmegaUI,代碼行數:21,代碼來源:socket_logging.py

示例3: on_connect

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def on_connect(self):
        print('A client connected')
        emit('connect', {'last_job_id': get_last_modification_job_id(self.db_session)}) 
開發者ID:HTTP-APIs,項目名稱:hydrus,代碼行數:5,代碼來源:sync_namespace.py

示例4: on_reconnect

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def on_reconnect(self):
        print('A client reconnected.')
        emit('connect', {'last_job_id': get_last_modification_job_id(self.db_session)}) 
開發者ID:HTTP-APIs,項目名稱:hydrus,代碼行數:5,代碼來源:sync_namespace.py

示例5: on_get_modification_table_diff

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def on_get_modification_table_diff(self, data):
        """Get modification table diff and emit it to the client.
        :param data: Dict with 'agent_job_id' key.
        """
        if 'agent_job_id' in data:
            agent_job_id = data['agent_job_id']
            modification_table_diff = get_modification_table_diff(self.db_session,
                                                                  agent_job_id)
        else:
            modification_table_diff = get_modification_table_diff(self.db_session)
        emit('modification_table_diff', modification_table_diff) 
開發者ID:HTTP-APIs,項目名稱:hydrus,代碼行數:13,代碼來源:sync_namespace.py

示例6: randomNumberGenerator

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def randomNumberGenerator():
    """
    Generate a random number every 1 second and emit to a socketio instance (broadcast)
    Ideally to be run in a separate thread?
    """
    #infinite loop of magical random numbers
    print("Making random numbers")
    while not thread_stop_event.isSet():
        number = round(random()*10, 3)
        print(number)
        socketio.emit('newnumber', {'number': number}, namespace='/test')
        socketio.sleep(5) 
開發者ID:shanealynn,項目名稱:async_flask,代碼行數:14,代碼來源:application.py

示例7: check_update

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def check_update(source_url = None, current_release = None, prerelease=False, emit = True):
    """
        Check if a RTKBase update exists
        :param source_url: the url where we will try to find an update. It uses the github api.
        :param current_release: The current RTKBase release
        :param prerelease: True/False Get prerelease or not
        :param emit: send the result to the web front end with socketio
        :return The new release version inside a dict (release version and url for this release)
    """
    new_release = {}
    source_url = source_url if source_url is not None else "https://api.github.com/repos/stefal/rtkbase/releases"
    current_release = current_release if current_release is not None else rtkbaseconfig.get("general", "version").strip("v")
    current_release = current_release.replace("-beta", "").replace("-alpha", "").replace("-rc", "")
    
    try:    
        response = requests.get(source_url)
        response = response.json()
        for release in response:
            if release.get("prerelease") & prerelease or release.get("prerelease") == False:
                latest_release = release.get("tag_name").strip("v").replace("-beta", "").replace("-alpha", "").replace("-rc", "")
                if latest_release > current_release and latest_release <= rtkbaseconfig.get("general", "checkpoint_version"):
                    new_release = {"new_release" : release.get("tag_name"), "url" : release.get("assets")[0].get("browser_download_url"), "comment" : release.get("body")}
                    break
             
    except Exception as e:
        print("Check update error: ", e)
        
    if emit:
        socketio.emit("new release", json.dumps(new_release), namespace="/test")
    print
    return new_release 
開發者ID:Stefal,項目名稱:rtkbase,代碼行數:33,代碼來源:server.py

示例8: update_rtkbase

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def update_rtkbase():
    """
        Check if a RTKBase exists, download it and update rtkbase
    """
    #Check if an update is available
    update_url = check_update(emit=False).get("url")
    if update_url is None:
        return

    import tarfile
    #Download update
    update_archive = "/var/tmp/rtkbase_update.tar.gz"
    try:
        response = requests.get(update_url)
        with open(update_archive, "wb") as f:
            f.write(response.content)
    except Exception as e:
        print("Error: Can't download update - ", e)

    #Get the "root" folder in the archive
    tar = tarfile.open(update_archive)
    for tarinfo in tar:
        if tarinfo.isdir():
            primary_folder = tarinfo.name
            break
    
    #Extract archive
    tar.extractall("/var/tmp")

    #launch update script
    rtk.shutdownBase()
    rtkbase_path = os.path.abspath(os.path.join(os.path.dirname(__file__), "../"))
    source_path = os.path.join("/var/tmp/", primary_folder)
    script_path = os.path.join(source_path, "rtkbase_update.sh")
    current_release = rtkbaseconfig.get("general", "version").strip("v")
    standard_user = rtkbaseconfig.get("general", "user")
    os.execl(script_path, "unused arg0", source_path, rtkbase_path, app.config["DOWNLOAD_FOLDER"].split("/")[-1], current_release, standard_user) 
開發者ID:Stefal,項目名稱:rtkbase,代碼行數:39,代碼來源:server.py

示例9: getAvailableLogs

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def getAvailableLogs():
    print("DEBUG updating logs")
    rtk.logm.updateAvailableLogs()
    print("Updated logs list is " + str(rtk.logm.available_logs))
    rtk.socketio.emit("available logs", rtk.logm.available_logs, namespace="/test")

#### str2str launch/shutdown handling #### 
開發者ID:Stefal,項目名稱:rtkbase,代碼行數:9,代碼來源:server.py

示例10: getAvailableSpace

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def getAvailableSpace():
    rtk.socketio.emit("available space", reach_tools.getFreeSpace(path_to_gnss_log), namespace="/test")

#### Delete log button handler #### 
開發者ID:Stefal,項目名稱:rtkbase,代碼行數:6,代碼來源:server.py

示例11: readRINEXVersion

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def readRINEXVersion():
    rinex_version = rtk.logm.getRINEXVersion()
    rtk.socketio.emit("current RINEX version", {"version": rinex_version}, namespace="/test") 
開發者ID:Stefal,項目名稱:rtkbase,代碼行數:5,代碼來源:server.py

示例12: update_settings

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def update_settings(json):
    """
        Get the form data from the web front end, and save theses values to settings.conf
        Then restart the services which have a dependency with these parameters.
        param json: A json variable containing the source fom and the new paramaters
    """
    print("received settings form", json)
    source_section = json.pop().get("source_form")
    print("section: ", source_section)
    if source_section == "change_password":
        if json[0].get("value") == json[1].get("value"):
            rtkbaseconfig.update_setting("general", "new_web_password", json[0].get("value"))
            update_password(rtkbaseconfig)
            socketio.emit("password updated", namespace="/test")

        else:
            print("ERREUR, MAUVAIS PASS")
    else:
        for form_input in json:
            print("name: ", form_input.get("name"))
            print("value: ", form_input.get("value"))
            rtkbaseconfig.update_setting(source_section, form_input.get("name"), form_input.get("value"), write_file=False)
        rtkbaseconfig.write_file()

        #Restart service if needed
        if source_section == "main":
            restartServices(("main", "ntrip", "rtcm_svr", "file"))
        elif source_section == "ntrip":
            restartServices(("ntrip",))
        elif source_section == "rtcm_svr":
            restartServices(("rtcm_svr",))
        elif source_section == "local_storage":
            restartServices(("file",)) 
開發者ID:Stefal,項目名稱:rtkbase,代碼行數:35,代碼來源:server.py

示例13: process_audio

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def process_audio(filepath):
    """ Process Audio component of Video
    """
    json_path = os.path.join(basedir, 'static', 'data', 'tmp_json')

    mean_energy = []
    max_pitch_amp = []
    vowel_duration = []
    pitch_contour = []

    output = convert_audio(filepath)

    for files in output:
        frames, framelength = audio.split(files)
        filteredframes = audio.applyhamming(frames)
        energy = audio.energy(filteredframes)
        fourier = audio.fourier(filteredframes)
        frames = audio.inverse_fourier(fourier)
        pitchamp, pitchperiod = audio.sampling(frames)

        # Implemented Features, read audio.py for return values
        data1 = audio.meanenergy(energy)
        data2 = audio.maxpitchamp(pitchamp)
        data3 = audio.vowelduration(pitchamp, data2)
        data4 = audio.fundamentalf(pitchperiod, framelength)

        mean_energy.append(data1)
        max_pitch_amp.append(data2)
        vowel_duration.append(data3)
        pitch_contour.append(data4)

    with shelve.open(os.path.join(json_path, 'audio_data.shlf')) as shelf:
        shelf['mean_energy'] = mean_energy
        shelf['max_pitch_amp'] = max_pitch_amp
        shelf['vowel_duration'] = vowel_duration
        shelf['pitch_contour'] = pitch_contour

    socketio.emit('data_complete', 'Audio_Complete')

    cleanup_audio() 
開發者ID:Notabela,項目名稱:Lie_to_me,代碼行數:42,代碼來源:process.py

示例14: test_message

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def test_message(message):
    flask.session['receive_count'] = flask.session.get('receive_count', 0) + 1
    pool.spawn(background_thread, message['data'])
    fsio.emit('log_response', {'data': message['data'], 'count': flask.session['receive_count']}) 
開發者ID:OmegaTrading,項目名稱:OmegaUI,代碼行數:6,代碼來源:socket_logging.py

示例15: connect

# 需要導入模塊: import flask_socketio [as 別名]
# 或者: from flask_socketio import emit [as 別名]
def connect():
    print('Client connected', flask.request.sid)
    fsio.emit('log_response', {'data': 'Connected', 'count': 0}) 
開發者ID:OmegaTrading,項目名稱:OmegaUI,代碼行數:5,代碼來源:socket_logging.py


注:本文中的flask_socketio.emit方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。