Tooth uncle tutorial is easy to understand

Results show

origin

Someone asked me how to do this effect, SO I studied it, I did not think of such demand, he said oppo is this style

The environment

Phone: Mi 11 Pro

Android version: 11

Autojs version: 9.0.10

Train of thought

  • This feature focuses on the edges
  • When a finger touches the edge of the screen, the hover window takes over the touch event

Here’s what you’ll learn

  • Create a suspension window in the shape of a thermometer
  • Mutual scheduling control between multiple suspension Windows
  • Hover window displays animation
  • How to use grid containers
  • Text Multiple ways to set rounded corners
  • Calculation method of suspension window center and edge fitting

note

When xiaomi tested the phone, the edge hover window, which was always on top of xiaomi’s own gesture function, we could only respond to touch events a little bit further away from the edge.

The code on

1. Edge hover window UI
let floatingRod = floaty.rawWindow(
  <card id="rod" cardCornerRadius="10dp">
    <vertical>
      <View id="rod1" clickable="true" bg="{{config.color.rod1.collapsed}}" w="16dp" h="100dp"></View>
      <View id="rod2" clickable="true" bg="{{config.color.rod2.collapsed}}" w="16dp" h="100dp"></View>
    </vertical>
  </card>
);
Copy the code
2. Display method of edge suspension window
function show() {
  let ww = floatingRod.width;
  let wh = floatingRod.height / 2;
  floatingRod.setPosition(device.width - ww, device.height / 2 - wh);
}
Copy the code
3. Monitoring of edge suspension Windows
floatingRod.rod1.setOnTouchListener(function (view, event) {
  switch (event.getAction()) {
    case event.ACTION_DOWN:
      log(" ACTION_DOWN");
      floatingRod.setPosition(-3000, -3000);
      menuWindow1Show();
      break;
  }
  return false;
});
Copy the code
4. Control to set rounded background
function setBackgroundRoundRounded(view, color) {
  let gradientDrawable = new GradientDrawable();
  gradientDrawable.setShape(GradientDrawable.RECTANGLE);
  gradientDrawable.setColor(colors.parseColor(color));
  gradientDrawable.setCornerRadius(60);
  gradientDrawable.setSize(50.50);
  view.setBackground(gradientDrawable);
}
Copy the code
5. UI of the middle suspension window
let floatingMenu = floaty.rawWindow(
  <vertical id="firstParent" alpha="0">
    <card cardCornerRadius="10dp">
      <vertical id="parent" padding="6">
        <text textSize="20sp" textColor="#ffffff" gravity="center_horizontal">Tooth tertiary tutorial</text>
        <scroll id="scroll" h="200dp">
          <grid id="menu" spanCount="2">
            <card cardCornerRadius="10dp" h="30dp" w="80dp" margin="9">
              <text
                textColor="#ccffffff"
                text="{{this.labelName}}"
                textSize="20sp"
                bg="{{this.labelColor}}"
                gravity="center"
              />
            </card>
          </grid>
        </scroll>
      </vertical>
    </card>
  </vertical>
);
Copy the code
6. Export functions to main program calls
function main(floatingRodShow) {
  floatingMenu.menu.on("item_click".function (item, i, itemView, listView) {
    toastLog(item.labelName);
    floatingRodShow();
    hide();
  });
  return show;
}

module.exports = main;
Copy the code

Quotes.

Ideas are the most important, other Baidu, Bing, StackOverflow, Github, Android docs, AutoJS docs, and last but not least, ask in the group

The statement

This tutorial is intended for learning purposes only and is not intended for any other use