• Recent
    • Tags
    • Popular
    • Register
    • Login

    Please Note This forum exists for community support for the Mango product family and the Radix IoT Platform. Although Radix IoT employees participate in this forum from time to time, there is no guarantee of a response to anything posted here, nor can Radix IoT, LLC guarantee the accuracy of any information expressed or conveyed. Specific project questions from customers with active support contracts are asked to send requests to support@radixiot.com.

    Radix IoT Website Mango 4 Documentation Website Mango 5 Documentation Website Radix IoT LinkedIn

    Slider step as a binary?

    Scheduled Pinned Locked Moved User help
    3 Posts 2 Posters 1.6k Views 2 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • S Offline
      SG
      last edited by

      Hey gents,

      I'm dealing with a slightly odd scenario, I'm trying to make a slider step via binary shifting (So the valid step states of the data point are 1, 2, 4, 8) But since this is being read/written via a standard integer, I can't do the validation on the device side.

      Any ideas on how to make this step work inside a standard Mango component? Doesn't have to be a slider, just that would be the most convenient.

      Thanks Guys.

      1 Reply Last reply Reply Quote 0
      • Jared WiltshireJ Offline
        Jared Wiltshire
        last edited by

        @SG
        The only way I could come up with is to put some code in a user module -

        define(['angular', 'require'], function(angular, require) {
        'use strict';
        
        var userModule = angular.module('userModule', ['maUiApp']);
        
        userModule.run(['maPoint', function(maPoint) {
            Object.defineProperty(maPoint.prototype, 'bitShiftValue', {
                get: function() {
                    return Math.log2(this.value);
                },
                set: function(value) {
                    this.setValue(1 << value);
                }
            });
        }]);
        
        return userModule;
        
        }); // define
        

        You can then put a slider on the page like this -

        <ma-get-point-value  point-xid="multistate-point-xid" point="myPoint"></ma-get-point-value>
        <md-slider ng-disabled="!myPoint.enabled" md-discrete step="1" min="0" max="3" ng-model="myPoint.bitShiftValue"></md-slider>
            
        

        Developer at Radix IoT

        S 1 Reply Last reply Reply Quote 0
        • S Offline
          SG @Jared Wiltshire
          last edited by

          @jared-wiltshire Cool. That works pretty slick.

          Thanks Jared.

          1 Reply Last reply Reply Quote 0

          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

          With your input, this post could be even better 💗

          Register Login
          • First post
            Last post