ComposableButtonToggleGroup is the implementation of MaterialButtonToggleGroup for Jetpack Compose
| Composable Button Toggle Group is the implementation of MaterialButtonToggleGroup for Jetpack Compose. | ![]()  | 
|---|
Add following line of code to your project level gradle file
  repositories {
    mavenCentral()
  }Add following line of code to your module(app) level gradle file
    implementation 'com.robertlevonyan.compose:buttontogglegroup:<Version>'    implementation("com.robertlevonyan.compose:buttontogglegroup:$Version")  <dependency>
    <groupId>com.robertlevonyan.compose</groupId>
    <artifactId>buttontogglegroup</artifactId>
    <version>Version</version>
    <type>pom</type>
  </dependency>  Box(modifier = Modifier.fillMaxSize()) {
    RowToggleButtonGroup(
      modifier = Modifier,
      buttonCount = 4,
      selectedColor = Color.Gray,
      unselectedColor = LightGray,
      selectedContentColor = Color.White,
      unselectedContentColor = DarkGray,
      elevation = ButtonDefaults.elevation(0.dp), // elevation of toggle group buttons
      buttonIcons = arrayOf(
        painterResource(id = R.drawable.ic_format_align_left),
        painterResource(id = R.drawable.ic_format_align_center),
        painterResource(id = R.drawable.ic_format_align_right),
        painterResource(id = R.drawable.ic_format_align_justify),
      ),
    ) { index ->
      // check index and handle click
    }
  }  Box(modifier = Modifier.fillMaxSize()) {
    ColumnToggleButtonGroup(
      modifier = Modifier,
      primarySelection = 0,
      buttonCount = 2,
      selectedColor = Color.Gray,
      unselectedColor = LightGray,
      selectedContentColor = Color.White,
      unselectedContentColor = DarkGray,
      elevation = ButtonDefaults.elevation(0.dp), // elevation of toggle group buttons
      buttonTexts = arrayOf("Android", "iOS"),
      buttonIcons = arrayOf(
        painterResource(id = R.drawable.ic_android),
        painterResource(id = R.drawable.ic_ios),
      ),
      iconPosition = IconPosition.Top,
    ) { index ->
      // check index and handle click
    }
  }Migrate to Material 3
Now you can specify icon position
Icon button support added, Text made single line
First version of library
- Email: [email protected]
 - Website: https://robertlevonyan.com/
 - Medium: https://medium.com/@RobertLevonyan
 - Twitter: https://twitter.com/@RobertLevonyan
 - Facebook: https://facebook.com/robert.levonyan
 - Google Play: https://play.google.com/store/apps/dev?id=5477562049350283357
 
    Composable Button Toggle Group©
    Copyright 2022 Robert Levonyan
    Url: https://github.com/robertlevonyan/composable-button-toggle-group
    Licensed under the Apache License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at
    http://www.apache.org/licenses/LICENSE-2.0
    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.


